👩💻 Обработка 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