Новости Joomla

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

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

  • Живу я здесь
  • 2787
  • 413 / 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 »
И какая разница к чему он относится?
не пойму вопроса честно говоря. как какая разница? :) а как понять куда редиректить, если мы не знаем что это за урл?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Джумла генерит ссылки

Автор Gleb72

Ответов: 2
Просмотров: 478
Последний ответ 15.02.2026, 13:31:36
от Gleb72
Замена данных сайта на данные поддомена

Автор rezchik

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

Автор web1

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

Автор Dolphin4ik_1

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

Автор Viktor_ist

Ответов: 1
Просмотров: 965
Последний ответ 07.05.2022, 09:42:02
от Viktor_ist