Новости 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

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

Zhanadil1509

  • Захожу иногда
  • 126
  • 0 / 0
Помогите улучшить запрос
« : 22.11.2017, 09:28:44 »
Доброго времени суток! в настройках импорта есть такой код, который отвечает на сопутствующие товары, который добавляет по id:

Код
if(count($data)) {
foreach($data as $r) {
$this->_db->setQuery("SELECT product_id
                              FROM #__jshopping_products
                              WHERE product_ean=" . $this->_db->Quote($r->sku));
$related_id = $this->_db->loadResult();
if($related_id) {
$this->_db->setQuery("INSERT INTO #__jshopping_products_relations SET product_id = '{$r->product_id}', product_related_id = '$related_id'");
$this->_db->Query();
}
else{
echo JText :: _('SKU_NOT_FOUND'). ":$r->sku<br>";
}
}
$this->_db->setQuery("TRUNCATE TABLE #__excel2js_related_products");
$this->_db->Query();
}

Как можно сделать так, чтобы при импорте мог через коллекцию товара составлять "сопутствующие товары", а не по id?
*

flyingspook

  • Живу я здесь
  • 3590
  • 247 / 9
Re: Помогите улучшить запрос
« Ответ #1 : 22.11.2017, 16:53:23 »
Заменить
Код
product_related_id = '$related_id'
на то что нужно, если нужного нет то предварительно вызвать
*

Zhanadil1509

  • Захожу иногда
  • 126
  • 0 / 0
Re: Помогите улучшить запрос
« Ответ #2 : 23.11.2017, 07:31:31 »
Заменить
Код
product_related_id = '$related_id'
на то что нужно, если нужного нет то предварительно вызвать

Нужно чтобы по коллекции сортировал. Это у нас - product_ean. Нужно ли его предварительно прописывать? Получается мне нужно будет в БД изменить строку porduct_related_id, потому что ведь запрос идет на строку в таблице БД. А перезапишет ли потом с таблицы товарами?
*

Zhanadil1509

  • Захожу иногда
  • 126
  • 0 / 0
Re: Помогите улучшить запрос
« Ответ #3 : 23.11.2017, 07:55:38 »
Менял на нужное значение, не работает результат.
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Помогите улучшить запрос
« Ответ #4 : 23.11.2017, 08:56:52 »
Менял на нужное значение
На такое
Код
if($related_id) {
$this->_db->setQuery("INSERT INTO #__jshopping_products_relations SET product_id = '{$r->product_id}', нужное = 'не_скажу'");
$this->_db->Query();
}
else{
echo JText :: _('ПОПРОБУЙ_УГАДАТЬ_ПОЧЕМУ_НЕ_РАОТАЕТ'). ":$r->sku<br>";
}
?
Не будь паразитом, сделай что-нибудь самостоятельно!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Привязка материала к метке через запрос к БД

Автор sk8work

Ответов: 4
Просмотров: 1070
Последний ответ 14.10.2022, 13:24:55
от sk8work
Цикличный SQL запрос, высокая нагрузка на mysqld

Автор tweenpix

Ответов: 4
Просмотров: 1046
Последний ответ 19.07.2022, 15:34:47
от tweenpix
Делаю запрос к базе к полю images, выдает пустые значения а они есть там

Автор Dolphin4ik_1

Ответов: 1
Просмотров: 683
Последний ответ 14.07.2022, 12:48:33
от sivers
!!!РЕШЕНО - Сайт не цепляет переопределение! Помогите

Автор onniby

Ответов: 4
Просмотров: 952
Последний ответ 04.05.2022, 12:47:09
от onniby
Запрос персональных данных

Автор web3.0

Ответов: 2
Просмотров: 1079
Последний ответ 02.09.2021, 16:13:24
от web3.0