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

Dram

  • Захожу иногда
  • 173
  • 0 / 0
Как зная ID материала получит на него ссылку ЧПУ? 

У меня такая структура - категории висят на меню, далее подкатегория и материал.
*

sivers

  • Давно я тут
  • 682
  • 70 / 0
Код
$link = JRoute::_('index.php?option=com_content&view=article&id=161&Itemid=124');
На связи в телеге @sivers
*

Dram

  • Захожу иногда
  • 173
  • 0 / 0
Так уже пробовал -

$link = JRoute::_('index.php?option=com_content&view=article&id=161&Itemid=2801');
echo $link;
выдает /component/content/?id=161&Itemid=2801
*

AlekVolsk

  • Гуру
  • 6789
  • 396 / 4
Itemid=2801 - у вас есть пункт меню с id 2801 ?  :o
*

Dram

  • Захожу иногда
  • 173
  • 0 / 0
Мне нужно получить ЧПУ зная только id материала и все
*

AlekVolsk

  • Гуру
  • 6789
  • 396 / 4
а без Itemid вы не получите URL с привязкой к меню, надо доп.запрос к базе делать, такой примерно:
Код: php
$article_id = 161; /* id вашего материала */
$db = Factory::getDbo();
$Itemid = (int)$db->setQuery('select `id` from `#__menu` where `type`="component" and `component_id`=22 and `link` like "%id=' . $article_id . '%"')->loadResult();

теперь в $Itemid будет искомое id связанного пункта меню или 0, если пункт меню не найден, если найден - значение всегда более 100
*

Dram

  • Захожу иногда
  • 173
  • 0 / 0
Попробовал - ничего не выдало. Напоминаю что на меню у меня висят только категории, а не материалы. Не понимаю смысл этой части
`link` like "%id=
*

AlekVolsk

  • Гуру
  • 6789
  • 396 / 4
Не понимаю смысл этой части
Код
`link` like "%id=' . $article_id . '%"'
на выходе в запросе это будет выглядеть как
Код
`link` like "%id=161%"'
sql-оператор link позволяет задавать условие с нестрогим соответствием по маске, символ % - любой символ в искомой строке

смысл всего запроса: найти id пункта меню, который имеет тип компонент, привязан к компоненту com_content (его id всегда 22, но это можно уточнить в таблице extensions), а поле link, которое содержит не-sef ссылку, ссылается на объект материала с искомым id (в частном случае 161)

если материал не привязан непосредственно к пункту меню - запрос вернёт 0
*

AlekVolsk

  • Гуру
  • 6789
  • 396 / 4
а вообще изначально некорректно подошли к проблеме, для материалов и их категорий есть отдельная функция получения ссылки:
Код
Joomla\CMS\HTML\HTMLHelper::addIncludePath(JPATH_ROOT . '/components/com_content/helpers');
$link = Joomla\CMS\Router\Route::_(ContentHelperRoute::getArticleRoute($article->slug, $article->catid, $article->language)); /* последний параметр необязателен, если у вас нет мультияза */

$article->slug формируется как $article->id . ':' . $article->alias;
« Последнее редактирование: 14.06.2019, 08:27:05 от AlekVolsk »
*

Dram

  • Захожу иногда
  • 173
  • 0 / 0
Спс не проверял вашу подсказу, сделал по другому :)))
У меня был массив ссылок НЕ ЧПУ.
Я включил на сайте плагин ноудублес и прошелся курлом по этим ссылкам собирая конечную после переадресации в массив :)))
*

AlekVolsk

  • Гуру
  • 6789
  • 396 / 4
оч странный подход, что-то изменится, добавится/удалится - и накроется ваш метод, или вы каждый раз так делать будете?
*

Dram

  • Захожу иногда
  • 173
  • 0 / 0
Мне это нужно было однократно :)))
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вышел релиз безопасности Joomla! 3.9.9 и баг-фикс 3.9.10

Автор b2z

Ответов: 49
Просмотров: 1247
Последний ответ 17.07.2019, 16:51:53
от apikron
Вышел релиз безопасности Joomla! 3.9.7 и баг-фикс релиз Joomla! 3.9.8

Автор b2z

Ответов: 20
Просмотров: 2242
Последний ответ 09.07.2019, 18:19:15
от b2z
Joomla! 3.4.8 расширение для формы заявок

Автор joonnikk

Ответов: 0
Просмотров: 94
Последний ответ 03.07.2019, 13:38:00
от joonnikk
Ошибки БД при Joomla 3.7.0

Автор deloputalo

Ответов: 31
Просмотров: 2811
Последний ответ 29.06.2019, 09:45:11
от daniilnikitin
Joomla 3.8.1 и CAPTCHA - reCAPTCHA v2

Автор pavel666

Ответов: 8
Просмотров: 2471
Последний ответ 28.06.2019, 11:06:23
от Cedars