Новости 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 Гость просматривают эту тему.
  • 4 Ответов
  • 1338 Просмотров
*

borro

  • Завсегдатай
  • 1379
  • 22 / 0
  • желаю вам счастья
Здравствуйте!

В разрабатываемом модуле возникла задача вывести помимо информации о товарах информацию о категории, из которой они берутся,  а именно название и описание.
Можно доработать SELECT запрос, добавив в него к каждой строке с информацией по товару название и описание категории, то есть создать некоторое дублирование информации. А можно отдельным запросом эту информацию вытащить. Как проверить, что будет более емко по времени исполнения?
*

SmokerMan

  • Гуру
  • 5291
  • 720 / 26
Код
$start = microtime(true);
//запрос
$time = microtime(true) - $start;
printf("Запрос выполнялся %.4F сек.", $time);
ну или включить отладку системы, правда хз там есть время запросов или нет
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
*

borro

  • Завсегдатай
  • 1379
  • 22 / 0
  • желаю вам счастья
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Отдельно в цикле? Жуть :)
Ну если у Вас маленькое количество товаров, то ещё может быть вариант, что SELECT в цикле быстрее JOIN. Пробуйте для интереса замерить, как SmokerMan написал.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Запрос в базу

Автор User82

Ответов: 5
Просмотров: 955
Последний ответ 28.10.2017, 12:29:03
от fsv
Два запроса к базе данных за раз можно делать?

Автор borro

Ответов: 4
Просмотров: 1361
Последний ответ 17.10.2017, 09:30:44
от SeBun
sql запрос для вывода правильной даты

Автор Frics

Ответов: 4
Просмотров: 1507
Последний ответ 04.07.2017, 14:17:22
от SeBun
Вывод данных из MySQL на сайт

Автор Frics

Ответов: 5
Просмотров: 2881
Последний ответ 20.06.2017, 13:21:49
от Septdir
Запрос на обновление данных

Автор web3.0

Ответов: 0
Просмотров: 1072
Последний ответ 30.04.2017, 21:30:12
от web3.0