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

Dram

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

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

sivers

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

Dram

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

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

AlekVolsk

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

Dram

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

AlekVolsk

  • Гуру
  • 6900
  • 407 / 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

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

AlekVolsk

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

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

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

AlekVolsk

  • Гуру
  • 6900
  • 407 / 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

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

AlekVolsk

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

Dram

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

Ошибка при установке Joomla на локальном сервере

Автор borro

Ответов: 4
Просмотров: 75
Последний ответ Сегодня в 14:37:32
от borro
Можно ли сменить название почти готового сайта на Joomla и не поломать всё

Автор vova630

Ответов: 5
Просмотров: 253
Последний ответ 25.03.2020, 17:50:06
от rsn
Вышел релиз безопасности Joomla 3.9.16

Автор b2z

Ответов: 21
Просмотров: 922
Последний ответ 19.03.2020, 14:43:10
от SeBun
Вышел релиз безопасности Joomla 3.9.15

Автор b2z

Ответов: 15
Просмотров: 3166
Последний ответ 10.03.2020, 18:36:53
от b2z
В админ панели нет системного меню

Автор aeruma

Ответов: 26
Просмотров: 638
Последний ответ 09.03.2020, 01:38:54
от aeruma