Новости Joomla

Загадочный параметр $live_site в configuration.php Joomla

Загадочный параметр $live_site в configuration.php Joomla

Давным-давно, когда Joomla ещё была маленькой, в неё внедрили параметр $live_site. В ней хранился домен текущего сайта на случай, если Joomla не могла его определить из-за неверной настройки сервера. Нужно это было для разных SEO-компонентов, для использования редиректов и т.д.

Со временем для работы собственно сайта этот параметр перестал быть нужным. Уже в начале 2010-х стали встречаться рекомендации оставлять этот параметр пустым, дабы оный не привёл к лишним проблемам и путанице. Тем более, в web-админке нет места, где его можно указать или посмотреть его значение. Только в configuration.php, а туда смотрят не часто.

Однако, параметр всё же остался в ядре Joomla. Зачем он нужен? А нужен он в 2-х случаях:

  • для работы класса Joomla\CMS\Uri\Uri, который часто используется в коде Joomla для работы методов
    Uri::root() и
    Uri::base(), а значит может влиять и на работу в том числе ajax-скриптов.
  • для работы Joomla в CLI - командной строке сервера. В случае если вы используете в вашем CLI-плагине методы опять-таки класса Uri, то CLI ничего не знает о текущем домене, так как запускается вне web-сервера.

Поэтому домен нужно указывать принудительно. Либо с помощью параметра командной строки

--live-site, например,
—live-site=https://site.ru/. Со слешем на конце, иначе в CLI адрес сайта станет
https://site.rujoomla.php.Либо в параметре
$live_site в файле configuration.php, так как
CliApplication берёт настройку оттуда, если параметр команды не указан или пуст.

⚠️ Иначе в качестве хоста и url класса Uri будет установлено https://joomla.invalid/set/by/console/application. В самом же коде команды получить параметр

$live_site можно из объекта приложения

<?php protected function doExecute(InputInterface $input, OutputInterface $output): int { //... $live_site = $this->getApplication()->get('live_site'); //... }

и исходя из этого строить дальнейшую логику.

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

Dantte

  • Новичок
  • 1
  • 0 / 0
Код: sql
TiendaTableOrderItems::store failed - Unknown column 'linked_table' in 'field list' SQL=INSERT INTO `jos_tienda_orderitems` ( `linked_table`,`order_id`,`product_id`,`orderitem_attributes`,`orderitem_attribute_names`,`orderitem_sku`,`orderitem_name`,`orderitem_quantity`,`orderitem_price`,`orderitem_attributes_price`,`orderitem_final_price`,`orderitem_tax`,`modified_date`,`linked_table_key` ) VALUES ( 'products','10','1','','','1','Calvin Klein','2','2700.00000','+0.00000','5400','0','2010-12-27 03:26:10','1' )



В чем может быть проблема?
*

brig

  • Moderator
  • 159
  • 9 / 0
  • www.tienda-shop.ru
Ну... багрепорт достоин похвалы.
С видео, все наглядно и красиво...  ^-^
Вот здесь почитайте. Disclaimer.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Новый метод оплаты. Platron

Автор Lexus1990

Ответов: 0
Просмотров: 4609
Последний ответ 14.09.2014, 20:20:07
от Lexus1990
Ошибка 502 Bad Gateway !

Автор Makintosh

Ответов: 2
Просмотров: 7557
Последний ответ 01.04.2013, 15:57:45
от Makintosh
Модуль поиска. Ошибка

Автор sorkirill

Ответов: 9
Просмотров: 7257
Последний ответ 26.02.2013, 04:52:57
от Shamanchik
Вылетает ошибка при добавлении товара в корзину

Автор K0sty@n

Ответов: 1
Просмотров: 5231
Последний ответ 17.12.2012, 14:11:35
от K0sty@n
Как вообще убрать способы оплаты и доставки?

Автор ease

Ответов: 7
Просмотров: 8015
Последний ответ 10.09.2012, 18:43:56
от hooten