Новости Joomla

Перевод и публикация интервью на греческом портале Joomla Утро, просматриваешь входящие письма и...

Перевод и публикация интервью на греческом портале Joomla 🇬🇷Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции.Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью. Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент. 🇬🇷 Интервью на греческом портале (joomla.gr)🌐 Оригинальное интервью (на английском)Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5

👩‍💻 Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5.В Joomla для выполнения внешних запросов из PHP к сторонним API используется класс Joomla\Http\Http напрямую или же Joomla\Http\HttpFactory, который возвращает для работы преднастроенный по умолчанию класс Http. О работе с HTTP-запросами подробно рассказывалось в статье 2021 года Создание внешних запросов с использованием HttpFactory (Joomla). Некоторые изменения касаются работы с ответами на запросы. Например, наш запрос:
use Joomla\Http\HttpFactory;$http = (new HttpFactory)->getHttp($options, ['curl', 'stream']);$response = $http->get('https://any-url.ru/api/any/endpoint');
Раньше можно было получить код ответа или тело ответа как свойство $response - $response->code или $response->body. Однако, Joomla, начиная с Joomla 4 во многом переходит на стандарты PSR. В частности для работы с HTTP-ответами - на PSR-7. Также хорошая статья на Хабре о PSR-7: PSR-7 в примерах.
Прямое обращение к свойствам code, headers, body объявлено устаревшим в Joomla 6.0.0 и обещают удалить в Joomla 7.0.0.
Вместо этого нужно работать с HTTP-ответом по стандартам PSR-7. Код ответа.Было $response->code. Стало $response->getStatusCode().Заголовки ответа.Было $response->headers. Стало $response->getHeaders().Тело ответа.Было $response->body. Стало (string)$response->getContents().В тело ответа теперь приходит не строка, а поток - объект класса Laminas\Diactoros\Stream. Поэтому его нужно привести к строке (если это json, к примеру): (string)$response->getContents(). Чаще всего в коде Joomla встречается именно такой вариант. Однако, есть и вариант с перемещением указателя чтения на начало потока:
// Получили ответ в виде потока$stream = $response->getBody();// "перемотали" на начало$stream->rewind();// Получили строковый ответ$json = $stream->getContents();
В итоге результат одинаковый.@joomlafeed#joomla #разработка #php

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!Файловый менеджер Quantum — одно...

Файловый менеджер Quantum — одно из самых популярных решений для Joomla, созданное разработчиком из сообщества Joomla, Дмитрием Цымбалом (@tsymbalmitia). Он делает Quantum удобным, безопасным и современным, обновляет его, исправляет уязвимости и отвечает пользователям — всё это в свободное от основной работы время.

Теперь настал момент для следующего шага: развитие проекта требует больше времени и ресурсов.

0 Пользователей и 1 Гость просматривают эту тему.
  • 27 Ответов
  • 2453 Просмотров
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Добрый день!
Не могу понять как сделать правильно замену ссылок и где это лучше делать.
Пример:
Приходит пользователь на сайт по ссылке "site.com/katalog-filtrov/vozdushnyy/tovar_name" я ищу в базе данных, какая у меня настоящая ссылка на "tovar_name" и подставляю свою ссылку, к примеру "site.com/katalog-filtrov/vozdushnyy-filtr/tovar_name".
В грубую я воткнул простенький алгоритм замены в index.php, который в корне лежит. Переделка урлов работает, но не могу из index.php никак обратиться к базе. Да и вообще я так понимаю эту переделку урлов надо делать в другом месте.
Подскажите пожалуйста, как это лучше реализовать?
Сейчас это выглядит вот так:
Код
$oldurl=$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
$newurl=explode('/', $oldurl);

if(!is_null($newurl[2]) and $newurl[1]=='katalog-filtrov'){

   //Пущь, пущь, пущь магия обращения к БД и это замечательно работает в phpMyAdmin
   //$category_name="select #__menu.`alias` from #__jshopping_products left join #__jshopping_products_extra_field_values on #__jshopping_products.extra_field_5 = #__jshopping_products_extra_field_values.id OR #__jshopping_products.extra_field_6 = #__jshopping_products_extra_field_values.id left join #__menu on #__jshopping_products_extra_field_values.`name_ru-RU`=#__menu.`title` where #__jshopping_products.`alias_ru-RU`='".$newurl[2]."' limit 1";

   header('Location: /katalog-filtrov/'.$category_name.'/'.$newurl[2]);
}
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #1 : 25.04.2018, 16:57:48 »
я ищу в базе данных, какая у меня настоящая ссылка на "tovar_name" и подставляю свою ссылку
Можно узнать, зачем вы это делаете? Почему сразу не давать правильную ссылку?
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Re: Замена ссылки с запросом к базе
« Ответ #2 : 25.04.2018, 17:00:56 »
У вас на сайте поменялась структура а вы не хотите терять пользователей из поиска по старым урлам?
Это именно в товарах?
Создание сайтов, шаблонов, помощь в решении проблем.
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #3 : 25.04.2018, 20:17:20 »
У вас на сайте поменялась структура а вы не хотите терять пользователей из поиска по старым урлам?
Это именно в товарах?
Да. Там более 300 000 ссылок на товары, очень много дублей и ошибок. Сайт не мой, и SEO специалисты этого сайта требуют сохранить все ссылки (по крайней мере 80% из них) на несколько месяцев, пока не пройдёт индексация на нормальные ссылки, без дублей и ошибок. Поэтому можно прилепить временный костыль, даже в index.php корневой.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #4 : 25.04.2018, 20:36:17 »
Поскольку вы не использовали API Joomla, то вам нужно указать настоящий префикс имен таблиц, а не #_. Потом, мало запрос написать, его нужно еще выпонить.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #5 : 25.04.2018, 20:56:19 »
Поскольку вы не использовали API Joomla, то вам нужно указать настоящий префикс имен таблиц, а не #_. Потом, мало запрос написать, его нужно еще выпонить.
Тут немного другая ситуация. Запрос к базе в index.php с помощью API Joomla не срабатывает. Если я делаю такие запросы из модуля, то всё проходит на ура, а вот тут затык. Возможно какая-то защита от дурака, а где следует воткнуть замену ссылкам правильно с помощью плагина или костыля - я не знаю, потому что не настолько специалист.

Вот у меня есть простенький модуль для запроса в некую таблицу:
Код
$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query->select('#__fields_values.field_id, #__content.title, #__fields_values.value');
$query->from('#__fields_values, #__content');
$query->where('(#__fields_values.field_id=26 OR #__fields_values.field_id=27 OR #__fields_values.field_id=33) AND #__fields_values.item_id=#__content.id');
$db->setQuery($query);
$result = $db->loadObjectList();
Всё работает шикарно. Видимо не совсем дурак пока ещё. А вот с заменой ссылок - не работает и я не знаю как заставить.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #6 : 25.04.2018, 21:18:05 »
Запрос к базе в index.php с помощью API Joomla не срабатывает.
Потому что вы делали это до того, как загружается Joomla framework.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #7 : 25.04.2018, 21:59:45 »
Потому что вы делали это до того, как загружается Joomla framework.
Так и вопрос то в том куда это поместить? В какой-нибудь роутер или ещё куда, где можно делать эту замену ссылок. :)
Я могу воткнуть топорный запрос к базе прямым подключением в index.php, но что то это не очень безопасно.
*

fsv

  • Живу я здесь
  • 2781
  • 411 / 2
Re: Замена ссылки с запросом к базе
« Ответ #8 : 25.04.2018, 22:23:31 »
Редирект в .htaccess
FAQ - редиректы в htaccess
Веб-разработка: заказ. Только новая разработка.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #9 : 25.04.2018, 22:49:12 »
В какой-нибудь роутер или ещё куда, где можно делать эту замену ссылок
Правильно, в com_jshopping/router.php. Еще лучше, написать плагинчик на событие onBeforeParseRoute.
Редирект в .htaccess
FAQ - редиректы в htaccess
Боюсь, что у него слишком много категорий.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #10 : 25.04.2018, 22:57:02 »
onBeforeParseRoute
Вот! Похоже начало проясняться. А что это за событие? Не могу найти в документации. Не подскажете?
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #11 : 26.04.2018, 00:04:27 »
В router.php есть строка
Код
$dispatcher->trigger('onBeforeParseRoute', array(&$vars, &$segments));
Это значит, что вам нужно написать плагин с функцией onBeforeParseRoute(&$vars, &$segments), где $segments - это ваша $newurl.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Замена ссылки с запросом к базе
« Ответ #12 : 26.04.2018, 00:55:38 »
А что это за событие? Не могу найти в документации.
в документации :) возьмите любой плагин который работает с роутером, например https://nevigen.com/ru/seo-joomshopping/plagin-postroeniya-polnogo-puti-joomshopping.html , и посмотрите принцип
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #13 : 26.04.2018, 08:53:22 »
Понял, благодарю за наводку. Теперь разберусь.
*

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Re: Замена ссылки с запросом к базе
« Ответ #14 : 26.04.2018, 09:02:26 »
А по старым урлам, которые вы изменить хотите товар открывается или 404?
Создание сайтов, шаблонов, помощь в решении проблем.
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #15 : 26.04.2018, 09:51:01 »
А по старым урлам, которые вы изменить хотите товар открывается или 404?
Товар. Смысл такой. В старой базе около 200 000 товаров, часть дубли, часть ошибки, в итоге реального товара там 60 000. Магазин был на битриксе, человек который делал его очень плохо понимал что делает (то что не понимал вписывал отдельными php файлами прямо в корень сайта), он сделал вместо характеристик товаров категории и соответственно создались дубли страниц. Получилось дублей примерно 200 000 * 4 = 800 000. SEO делали несколько лет и не хотят терять наработанное. Поэтому я придумываю разные способы и алгоритмы, что бы сохранить все ссылки, до чего то там через несколько месяцев с индексацией.
То есть на один правильный товар может вести 3-10 старых индексированных ссылок из поисковиков, а на сайте преобразовывается в одну ссылку.
*

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Re: Замена ссылки с запросом к базе
« Ответ #16 : 26.04.2018, 09:58:47 »
Если нужный товар всё же открывается по всяким разным ссылкам, то просто склейте дубли прямо в шаблоне материала.
Файл components\com_jshopping\templates\default\product\product_default.php (Ну или в Вашем шаблоне)
Код
<?php 
$productlink = 'index.php?option=com_jshopping&controller=product&task=view&category_id='.$this->category_id.'&product_id='.$this->product->product_id;
if (JRoute::_($productlink)!= JRequest::getURI()) JApplication::redirect(JRoute::_($productlink),'','' ,true);
?>
Создание сайтов, шаблонов, помощь в решении проблем.
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #17 : 26.04.2018, 10:51:20 »
Если нужный товар всё же открывается по всяким разным ссылкам, то просто склейте дубли прямо в шаблоне материала.
Файл components\com_jshopping\templates\default\product\product_default.php (Ну или в Вашем шаблоне)
Код
<?php 
$productlink = 'index.php?option=com_jshopping&controller=product&task=view&category_id='.$this->category_id.'&product_id='.$this->product->product_id;
if (JRoute::_($productlink)!= JRequest::getURI()) JApplication::redirect(JRoute::_($productlink),'','' ,true);
?>
:) нет, в нынешнем каталоге всё ровно и дублей нет. Ссылки в Google и Яндекс лежат.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Замена ссылки с запросом к базе
« Ответ #18 : 26.04.2018, 10:57:42 »
Если нужный товар всё же открывается по всяким разным ссылкам, то просто склейте дубли прямо в шаблоне материала.
так и есть, самое простое решение.

:) нет
:) да
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Zelyonkin

  • Захожу иногда
  • 110
  • 0 / 0
Re: Замена ссылки с запросом к базе
« Ответ #19 : 26.04.2018, 12:25:49 »
Простого решения нет.
Старые ссылки могут быть такие, все для одного товара:
/katalog-filtrov/vozdushnyy-filtr-prefiltr/35363423sub-ingeoll-rand/
/katalog-filtrov/avtobus/35363423sub-ingeoll-rand/
/katalog-filtrov/ingeoll-rand/35363423sub-ingeoll-rand/
/katalog-filtrov/vozdushnyy/35363423sub/
/katalog-filtrov/vozdushnyy/35363423sub-/

А новая ссылка одна и она такого вида:
/katalog-filtrov/ingeoll-rand/35363423sub
Именно к такому виду и привожу их. Редирект не самое здесь страшное. И таких ссылок 300 000.
*

Efanych

  • Глобальный модератор
  • 4683
  • 644 / 0
  • Меняю свою жизнь на 360°!
Re: Замена ссылки с запросом к базе
« Ответ #20 : 26.04.2018, 12:29:28 »
Простого решения нет.
Старые ссылки могут быть такие, все для одного товара:
Если по всем ссылкам открывается нужный товар, то решение, которое я предложил всё исправит.
Создание сайтов, шаблонов, помощь в решении проблем.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #21 : 26.04.2018, 12:41:40 »
Если по всем ссылкам открывается нужный товар, то решение, которое я предложил всё исправит.
Верно.
@Zelyonkin Вы хоть пробовали это делать? Смысл в том, что по какой бы ссылке ни кликнул посетитель, в конце концов открывается шаблон товара, а тут уже делается сравнение с правильной ссылкой и перенаправляется на нее.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Замена ссылки с запросом к базе
« Ответ #22 : 26.04.2018, 22:23:33 »
Вы хоть пробовали это делать?
не, ну вы прям так рубите с плеча... впереди маячит долгий, примерно на пару страниц, этап уговоров :)

И таких ссылок 300 000.
их может быть хоть в 100500 раз больше. но если по ним открываются товары, то
решение, которое я предложил всё исправит.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Замена ссылки с запросом к базе
« Ответ #23 : 27.04.2018, 15:39:38 »
А почему бы этот код с поиском правильной ссылки не повесить в начале index.php шаблона (где будет работать все API движка) и там не редиректить посетителя на правильный URL? Просто топорное решение в лоб, после переиндексации можно убрать.
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Замена ссылки с запросом к базе
« Ответ #24 : 27.04.2018, 17:34:21 »
в начале index.php шаблона не будет понятно, к чему относится этот урл - это карточка товара, или может быть что-то другое
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: Замена ссылки с запросом к базе
« Ответ #25 : 27.04.2018, 21:17:17 »
в начале index.php шаблона не будет понятно, к чему относится этот URL - это карточка товара, или может быть что-то другое
И какая разница к чему он относится?
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Замена ссылки с запросом к базе
« Ответ #26 : 27.04.2018, 21:33:11 »
И какая разница к чему он относится?
1. Это стремно.
2. Это неэкономно: зачем проверять любой клик, еще и с запросом в БД?
Не будь паразитом, сделай что-нибудь самостоятельно!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Замена ссылки с запросом к базе
« Ответ #27 : 27.04.2018, 22:51:43 »
И какая разница к чему он относится?
не пойму вопроса честно говоря. как какая разница? :) а как понять куда редиректить, если мы не знаем что это за урл?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Замена данных сайта на данные поддомена

Автор rezchik

Ответов: 5
Просмотров: 1083
Последний ответ 05.02.2024, 11:45:36
от web1
Поменять цвет ссылки справа!

Автор web1

Ответов: 3
Просмотров: 1101
Последний ответ 30.12.2022, 10:46:42
от sivers
Делаю запрос к базе к полю images, выдает пустые значения а они есть там

Автор Dolphin4ik_1

Ответов: 1
Просмотров: 683
Последний ответ 14.07.2022, 12:48:33
от sivers
Перестали работать ссылки внутри сайта

Автор Viktor_ist

Ответов: 1
Просмотров: 816
Последний ответ 07.05.2022, 09:42:02
от Viktor_ist
Как убрать ссылки соц сетей на странице?

Автор 2ra

Ответов: 2
Просмотров: 1325
Последний ответ 03.05.2022, 17:28:54
от marksetter