Новости Joomla

Перевод и публикация интервью на греческом портале Joomla Утро, просматриваешь входящие письма и...

Перевод и публикация интервью на греческом портале Joomla 🇬🇷Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции.Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью. Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент. 🇬🇷 Интервью на греческом портале (joomla.gr)🌐 Оригинальное интервью (на английском)Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5

👩‍💻 Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5.В Joomla для выполнения внешних запросов из PHP к сторонним API используется класс Joomla\Http\Http напрямую или же Joomla\Http\HttpFactory, который возвращает для работы преднастроенный по умолчанию класс Http. О работе с HTTP-запросами подробно рассказывалось в статье 2021 года Создание внешних запросов с использованием HttpFactory (Joomla). Некоторые изменения касаются работы с ответами на запросы. Например, наш запрос:
use Joomla\Http\HttpFactory;$http = (new HttpFactory)->getHttp($options, ['curl', 'stream']);$response = $http->get('https://any-url.ru/api/any/endpoint');
Раньше можно было получить код ответа или тело ответа как свойство $response - $response->code или $response->body. Однако, Joomla, начиная с Joomla 4 во многом переходит на стандарты PSR. В частности для работы с HTTP-ответами - на PSR-7. Также хорошая статья на Хабре о PSR-7: PSR-7 в примерах.
Прямое обращение к свойствам code, headers, body объявлено устаревшим в Joomla 6.0.0 и обещают удалить в Joomla 7.0.0.
Вместо этого нужно работать с HTTP-ответом по стандартам PSR-7. Код ответа.Было $response->code. Стало $response->getStatusCode().Заголовки ответа.Было $response->headers. Стало $response->getHeaders().Тело ответа.Было $response->body. Стало (string)$response->getContents().В тело ответа теперь приходит не строка, а поток - объект класса Laminas\Diactoros\Stream. Поэтому его нужно привести к строке (если это json, к примеру): (string)$response->getContents(). Чаще всего в коде Joomla встречается именно такой вариант. Однако, есть и вариант с перемещением указателя чтения на начало потока:
// Получили ответ в виде потока$stream = $response->getBody();// "перемотали" на начало$stream->rewind();// Получили строковый ответ$json = $stream->getContents();
В итоге результат одинаковый.@joomlafeed#joomla #разработка #php

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!Файловый менеджер Quantum — одно...

Файловый менеджер Quantum — одно из самых популярных решений для Joomla, созданное разработчиком из сообщества Joomla, Дмитрием Цымбалом (@tsymbalmitia). Он делает Quantum удобным, безопасным и современным, обновляет его, исправляет уязвимости и отвечает пользователям — всё это в свободное от основной работы время.

Теперь настал момент для следующего шага: развитие проекта требует больше времени и ресурсов.

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

rsn

  • Давно я тут
  • 520
  • 34 / 3
Дорогие профи!
(вопрос явно не начального уровня  ^-^)

Как мы знаем, любимая нами CMS может работать не только с базами типа MySQL, он и с другими типами баз.
В частности, например с базами MS SQL Server. Это заложено в движке.

Примерно так можно выбрать работу через драйвер sqlsrv - если на сервере работает PHP расширение SQLSRV:
Код
$option = [];   
$option['driver']   = 'sqlsrv';
$option['host']     = '83.142.XXX.XX';
$option['user']     = 'LOGIN';
$option['password'] = 'PASSWORD';
$option['database'] = 'DBNAME';
$db = JDatabaseDriver::getInstance($option);

$query = '
    SELECT TOP 5
        _Code, _Fld124
    FROM _Reference18
';
$db->setQuery($query);
$result = $db->loadObjectList();
Для SQLSRV есть отдельный файл драйвер в папке /libraries/joomla/database/driver - он так и называется sqlsrv.php.
Но не всегда есть возможность установить на сервере данное PHP расширение..

Между тем, работать с MS SQL можно также через pdo_dblib
В моём случае это то, что есть на сервере и можно использовать.

Поглядев на файлы драйверов, понимаю, что Joomla и с этим способна подружиться. Но нет отдельного драйвера dblib, есть драйвер pdo.php (всё в той же директории).
А в нём, как я понял, предусмотрена и работа в том числе через dblib.
Но на текущий момент пока не понял - как именно это задействовать в коде своего скрипта?
Может кто знает / сталкивался?

На просторах.. поискал, конечно. Не так много имеется. Вот тут, например, (германский Joomla форум) человек тоже спрашивает - и тишина... )

Если кому интересно для чего это - чтобы напрямую коннектится к базе 1С, не через программу, а напрямую к её базе.
Хочу подтягивать все продажи за период, чтобы лучше всего определять Сопутствующие товары.
Сначала сделали это средствами 1С-ки. Ой, туго она это делает..
Лучше сам сделаю на PHP  ;)
Возможно, будет интересно: Интеграция с Ozon
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Т.е., не Joomla с пдо надо дружить, а напрямую из PHP?

Вот что-то в конспекте есть:
Спойлер
[свернуть]
Внизу там ссылки не бесполезные. Которые были источником инфы. Правда там в примере подключение к sqllite, но принцип одинаковый для всех баз в пдо (вроде как).
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Спасибо, @sivers, посмотрю с удовольствием!
Но вообще хотел именно средствами Joomla работать. Напрямую можно, тут вопросов не должно быть, но это менее предпочтительно.
Возможно, будет интересно: Интеграция с Ozon
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Свой вопрос ещё могу переформулировать так:
Как прописать в скрипте, что хочу работать именно через драйвер PDO_DBLIB ?

Код
$option['driver']   = 'dblib';
...
$db = JDatabaseDriver::getInstance($option);
- так не заработало.
Возможно, будет интересно: Интеграция с Ozon
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
- так не заработало.
Так там нет такого драйвера. Есть pdomysql, pdo, sqlsrv и еще несколько. Посмотреть можно здесь:
/libraries/joomla/database/driver/
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
В отличие к примеру от файла mysqli.php (где определяется класс JDatabaseDriverMysqli, с которым можно работать),
файл pdo.php определяет абстрактный класс. То есть, как я понимаю, работать с ним нельзя. Но можно расширить его, и работать с дочерним классом.

Кроме того, файл pdo.php содержит такие строки:
Код
case 'dblib':
    $this->options['port'] = ...
По мне, так это свидетельство того, что с DBLIB он может работать.

Кажется, решение уже близко )
Возможно, будет интересно: Интеграция с Ozon
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Наверно, надо сделать новый файл pdodblib.php (по аналогии с pdomysql.php) в котором определить класс, расширяемый от JDatabaseDriverPdo.
Возможно, будет интересно: Интеграция с Ozon
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Это интересно - расскажите, если получится.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Так как результат нужен срочно  ^-^ , пока решил использовать PDO напрямую, без средств Joomla.
Но когда-нибудь к этому вернусь... наверно )
Возможно, будет интересно: Интеграция с Ozon
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Joomla 3 не пускает в админку (просто перезагружается страница) (гуглил, нашёл решение, не помогло)

Автор lifelover2b

Ответов: 11
Просмотров: 4886
Последний ответ 05.06.2025, 04:48:29
от andrey222
По поводу сессий Joomla 3

Автор azm1n

Ответов: 0
Просмотров: 1275
Последний ответ 25.05.2025, 09:26:17
от azm1n
Стоит ли ставить плагин rel="canonical" на Joomla 3

Автор azm1n

Ответов: 2
Просмотров: 1639
Последний ответ 09.05.2025, 12:39:18
от azm1n
Вывести поля профиля Joomla

Автор romagromov

Ответов: 11
Просмотров: 2841
Последний ответ 28.04.2025, 10:25:44
от sivers
Вставка видео со своего сервера через media manager

Автор goga_pgasovav

Ответов: 2
Просмотров: 1540
Последний ответ 27.03.2025, 14:51:43
от Akeksandr