Новости Joomla

Загадочный параметр $live_site в configuration.php 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 можно из объекта приложения

protected function doExecute(InputInterface $input, OutputInterface $output): int    {         //...              $live_site = $this->getApplication()->get('live_site');         //...    }
и исходя из этого строить дальнейшую логику.@joomlafeed#joomla #разработка #php #cli

Вышел плагин AllVideos v.7.0 от JoomlaWorks

Вышел плагин AllVideos v.7.0 от JoomlaWorks

Вышел плагин AllVideos v.7.0 от JoomlaWorks.Этот контент-плагин - одно из старейших расширений для Joomla. Его задача - преобразовывать шорт-коды вида

{YOUTUBE}...{/YOUTUBE},
{MP3}parth/to/file.mp3{/MP3} и подобные во встроенные видео или аудио.👩‍💻 v.7.0.0. Что нового?- Добавлена поддержка Youtube Shorts. Просто скопируйте полный url видео и вставьте его внутри тегов
{YOUTUBE}...{/YOUTUBE}.- Поддержка Joomla 5.x без плагина обратной совместимости. PHP 5, PHP 7, PHP 8. - Индексация умным поиском в CLI. В Joomla 5 плагин перестал вызывать ошибку при индексации контента умным поиском через CLI,Заметьте, что этот один и тот же пакет для всех версий Joomla, начиная с 1.5.x и заканчивая 5.x. Технически "под капотом" код плагина по сути не менялся, а для поддержки следующих версий Joomla авторы вставляют "заплатки". Плагин всё ещё использует старую архитектуру файлов и классов Joomla, что, к сожалению, заставляет прибавлять к его описанию слова "пока ещё" - "пока ещё работает".
Страница расширенияGitHub расширенияJoomla Extensions Directory👩‍💻 За ссылку спасибо самому внимательному участнику нашего сообщества - Ринату Кажетову (@rkazhet).@joomlafeed#joomla #расширения

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

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Подскажите пожалуйста как составить запрос для добавления новости в базу Joomla, не через админку, а через скрипт. Может у кого не будь есть готовые примеры запросов? Я в Google искал ничего не нашёл...
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Код
$query_add = 'insert into #__content set '.
'introtext = '.$intro.', '.
'fulltext = '.$fulltext.', '.
'created_date = "'.$date.'";';
и так далее. все обазательные поля заполняете.
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
я составил вот такой запрос, текст в базу записался н оне вывелся, на морде подскажите пожалуйста, что дописать надо(а лучше за меня допишите ::))

<?php

$db = mysql_connect("localhost","admin","252197");
mysql_select_db("jomla" ,$db);

$result = mysql_query ("INSERT INTO jos_content (title, alias, introtext ) VALUES ('Это тест ', 'this-is-sparta', 'this-is-sparta, this-is-sparta, this-is-sparta, this-is-sparta') ");

if ($result == true)
{
echo 'всё ништяк';
}
else
{
echo'не сработало';
}

mysql_close($db);

?>

*

Shustry

  • Гуру
  • 6434
  • 745 / 3
...а лучше за меня допишите ::))
Ну хоть честно написал.
Код: php
$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla
/*составляем запрос:*/
$result = "INSERT INTO #__content (title, introtext,  fulltext) VALUES ('Это тест ', 'this-is-sparta', 'this-is-sparta, this-is-sparta, this-is-sparta, this-is-sparta') "; //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla
$db->setQuery($result); //выполняем запрос
if ($db->query()) {
//проверяем, правильно ли всё сделали
echo 'это спарта, блеать!';
}
//А чтобы вывести, нужно другой запрос сотавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
Ну хоть честно написал.
Код: php
$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla
/*составляем запрос:*/
$result = "INSERT INTO #__content (title, introtext,  fulltext) VALUES ('Это тест ', 'this-is-sparta', 'this-is-sparta, this-is-sparta, this-is-sparta, this-is-sparta') "; //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla
$db->setQuery($result); //выполняем запрос
if ($db->query()) {
//проверяем, правильно ли всё сделали
echo 'это спарта, блеать!';
}
//А чтобы вывести, нужно другой запрос сотавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)


Он же со стороннего скрипта подключается)) Чтобы статья вывелась на сайте ее как минимум надо опубликовать. С ходу не вспомню, но надо в одном из полей таблицы с контентом выставить 1
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
mohax, так ему что добавлять, что выбирать надо напрямую запросами, там неважно, даже если половина полей будет пустая. Мы ж конкретные данные выбираем. Статья может быть и неопубликованной и автора не иметь ^-^.
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
я поставил 1-ки в табличке jos_content где это можно, но что то не выводится контент
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Расскажите, как выводите
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
mohax, так ему что добавлять, что выбирать надо напрямую запросами, там неважно, даже если половина полей будет пустая. Мы ж конкретные данные выбираем. Статья может быть и неопубликованной и автора не иметь ^-^.
НУ он же хочет опубликовать статью сразу)) Про пустые поля - это понятно. Эх, БД под рукой нет.
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Расскажите, как выводите

открыл через phpmyadmin табличку jos_content в которой опубликованы новости. Посмотрел какие ячеки в табличке заполнены у новости, которая добавлена через админку и какие ячеки заполнены у новости, добавленой скриптом. Выбрал редактировать новость добавленую скриптом и дописал в те ячейки кое что... но это не сработало, новость всё равно не отображается
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
я поставил 1-ки в табличке jos_content где это можно, но что то не выводится контент
Не надо где это можно. Поле state отвечает за это. А Вы не на главной хотите вывести случайно?
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Да вот хз, что он хочет :)))
Если сразу опубликовать, то пишем:
title - заголовок
introtext - вводный
catid - айдишнег категории
state = 1 - опубликовано
access = 1 - доступно
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Если на главной, то это ещё и в content_frontpage надо писать пару id_статьи/порядок.
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
Да вот хз, что он хочет :)))
Если сразу опубликовать, то пишем:
title - заголовок
introtext - вводный
catid - айдишнег категории
state = 1 - опубликовано
access = 1 - доступно
Точно, еще же access есть. =)
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Если сразу опубликовать, то пишем:
title - заголовок
introtext - вводный
catid - айдишнег категории
state = 1 - опубликовано
access = 1 - доступно

я вот так написал

<?php

$db = mysql_connect("localhost","admin","252197");
mysql_select_db("jomla" ,$db);

$result = mysql_query ("INSERT INTO jos_content (title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '25',  '1',  '1' );

if ($result == true)
{
echo 'всё ништяк';
}
else
{
echo'не сработало';
}

mysql_close($db);

?>

но опять ничего не вывелось... точнее небыло даже написано "не сработало" а просто белый экран...
« Последнее редактирование: 19.06.2012, 11:27:04 от Vovk@ »
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
А зачем вы так написали, если я выше написал, как надо написать? ^-^
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
что то я затупил, пойду учить мат часть :o
« Последнее редактирование: 19.06.2012, 12:32:31 от Vovk@ »
*

sergoguga

  • Давно я тут
  • 896
  • 70 / 8
  • www.mpbox.ru
мне кажется, дело в тексте... "это спарта, б***" )))) попробуйте нормальный текст вставить))))
>>> Верстка 100 евро - ждешь новый курс? Пиши!
>>> Создание моб. приложений по ГОСТу)))! Личка работает!
>>> Микроразметка по стандартам - цены адекват! Пиши, не боись!
>>> Личный кабинет на ZOO - уже сделан! Пиши в личку, не стесняйся!
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
Код
$result = mysql_query ("INSERT INTO jos_content (title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '25''1''1' );
Посмотрите порядок полей и что Вы пытаетесь них записать. state = 0 или 1. А Вы туда 25 запихиваете.
Я так и не понял. В базу у Вас пишет скрипт не имеющий отношения к Joomla  или все таки какое-то расширение для CMS?
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
В базу у Вас пишет скрипт не имеющий отношения к Joomla  или все таки какое-то расширение для CMS?

скрипт совершено постороний, никакого отношения к Joomla не имеет, но мне очень упростит жизнь
« Последнее редактирование: 19.06.2012, 14:00:15 от Vovk@ »
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
я исправил ошибку с категорией, но всё равно белый экран вижу когда открываю скрипт через браузер или 404 страничку джумы и всё
« Последнее редактирование: 19.06.2012, 14:03:22 от Vovk@ »
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
я исправил ошибку с категорией, но всё равно белый экран вижу когда открываю скрипт через браузер или 404 страничку джумы и всё
Ну и кавычку со скобкой Вы тоже закрыли?
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Ну и кавычку со скобкой Вы тоже закрыли?

закрыл, но всё равно ничего не получается

когда этот код вставляю

Цитировать
<?php

$db = mysql_connect("localhost","admin","252197");
mysql_select_db("jomla" ,$db);

$result = mysql_query ("INSERT INTO jos_content (title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '1',  '25',  '1' ) ");

if ($result == true)
{
echo 'всё ништяк';
}
else
{
echo'не сработало';
}

mysql_close($db);

?>

и через браузер открываю выводится - не сработало

а когда этот код вставляю

Цитировать

$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla
/*составляем запрос:*/
$result = "INSERT INTO #__title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '1',  '25',  '1' ) "); //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla
$db->setQuery($result); //выполняем запрос
if ($db->query()) {
//проверяем, правильно ли всё сделали
echo 'это спарта, блеать!';
}
//А чтобы вывести, нужно другой запрос соcтавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)


и через браузер открываю, вижу

Цитировать
$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla /*составляем запрос:*/ $result = "INSERT INTO #__content title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '1', '25', '1' ) "); //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla $db->setQuery($result); //выполняем запрос if ($db->query()) { //проверяем, правильно ли всё сделали echo 'это спарта, блеать!'; } //А чтобы вывести, нужно другой запрос соcтавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)

что я не так делаю...
« Последнее редактирование: 19.06.2012, 18:38:42 от Vovk@ »
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Возьмите любой шаблон Joomla, можно из установленных. Удалите нах всё из index.php, вставьте мой код и работайте с API Joomla.
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Возьмите любой шаблон Joomla, можно из установленных. Удалите нах всё из index.php, вставьте мой код и работайте с API Joomla.

нашёл шаблон по адресу .ru/templates/mitra_darkblue/index.php всё удалил из index.php вставил код, вот этот

Цитировать
$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla
/*составляем запрос:*/
$result = "INSERT INTO #__INSERT INTO #__content (title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '1',  '25',  '1' ) "); //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla
$db->setQuery($result); //выполняем запрос
if ($db->query()) {
//проверяем, правильно ли всё сделали
echo 'это спарта, блеать!';
}
//А чтобы вывести, нужно другой запрос сотавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)

и открыв через браузер увидел вот что

Цитировать
$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla /*составляем запрос:*/ $result = "INSERT INTO #__INSERT INTO #__content (title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '1', '25', '1' ) "); //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla $db->setQuery($result); //выполняем запрос if ($db->query()) { //проверяем, правильно ли всё сделали echo 'это спарта, блеать!'; } //А чтобы вывести, нужно другой запрос сотавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)

 :( :( :(
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
дубль :dry:
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Т.е. вы реально этот текст в браузере увидели? Забыли обернуть всё это дело в <?php ?> чтоли? ^-^
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Т.е. вы реально этот текст в браузере увидели? Забыли обернуть всё это дело в <?php ?> чтоли? ^-^

кстати да, забыл, с кем не бывает, щас поправил код но всё равно не работает, теперь просто белая страница и всё...
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
http://joomlaforum.ru/index.php/topic,195678.msg1116664.html#msg1116664
Вот тут я аналогичным способом работал с БД. Т.е. подключался из index.php шаблона, выбирал, обрабатывал, записывал. Так что способ проверенный.
Могу что посоветовать:
1. Сделайте вардамп составленного запроса
2. Вставьте тупо в поле sql-запрос панели phpmyadmin вставив, предварительно, префикс принудительно.
3. Проверяйте. Скорее всего ошибка в синтаксисе запроса. Не забывайте квотировать нужные поля.
*

Vovk@

  • Осваиваюсь на форуме
  • 30
  • 1 / 0
Вот такой запрос сработал



новость добавилась в базу данных, через админку её видно но она только для зарегестрированных пользовалетей, а нужно чтобы была для всех...

а потом я добавил тот же запрос в скрипт

Цитировать
<?php

$db = JFactory::getDbo(); //к базе так подключаемся. Привыкаем пользоваться API Joomla
/*составляем запрос:*/
$result = ("INSERT INTO jos_content (title, introtext , state, catid, access) VALUES ('Это тест ', 'this-is-sparta', '1',  '25',  '1' ) "); //альас как раз можно не писать, а где фуллтекст? Добавил. И префекс таблиц совсем не обязательно писать, когда работаем с Joomla
$db->setQuery($result); //выполняем запрос
if ($db->query()) {
//проверяем, правильно ли всё сделали
echo 'это спарта, блеать!';
}
//А чтобы вывести, нужно другой запрос сотавлять, выбирать данные, выводить. Но это уже совсем другая сказка :)

?>

но что-то он не сработал и всё равно белый экран... :o
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Joomla 1.5 как убрать кнопку редактировать материант с сайта

Автор andriy465

Ответов: 5
Просмотров: 3214
Последний ответ 12.11.2023, 23:37:03
от all_zer
Нужно wiki под Joomla

Автор THE KILLERS

Ответов: 9
Просмотров: 9386
Последний ответ 05.11.2020, 20:56:47
от Kijv
Поиск статьи по url сайта в админке Joomla 1.5

Автор Tema

Ответов: 5
Просмотров: 1794
Последний ответ 14.08.2020, 07:16:44
от rsn
Не могу войти в админку Joomla 1.5

Автор MrSkif

Ответов: 14
Просмотров: 10233
Последний ответ 12.09.2018, 19:36:32
от PaLyCH
Как вывести список новых статьи?

Автор maxo127

Ответов: 4
Просмотров: 2249
Последний ответ 16.06.2018, 02:44:50
от maxo127