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

Aleshka

  • Захожу иногда
  • 73
  • 2 / 0
Есть поле в БД и мне нужно заменить значения поля  (show_image) для одной записи с 1 в 0, а для какой-то другой наоборот выставить в 1 . Поле имеет тип tinyint(1). Сам sql запрос у меня получился такой, но проблема в том что у меня не обновляются данные, уже 2 часа не могу понять в чем дело:
Код
$query='SELECT * from #__atmap_country where show_image=1';
$this->_db->setQuery($query);
$row=$this->_db->loadAssoc();

// Вот эти строки похоже не работают.
$query="UPDATE #__atmap_country SET show_image=0  WHERE id=".(int)$row['id'];
$this->_db->setQuery($query);
$query="UPDATE #__atmap_country SET show_image=1 WHERE id=".(int)$id;
$this->_db->setQuery($query);
*

Aleshka

  • Захожу иногда
  • 73
  • 2 / 0
Такое ощущение, что не Joomla игнорирует выполенений запроса Update. В model создал метод и в  нем указал простое действие:
Код
$query='UPDATE #_atmap_country SET show_image=1  WHERE id=2';
$this->_db->setQuery($query);
При этом в БД в таблице jos_atmap_country у записи с id=2 установил show_image=0 и результат после выполнения осnался прежним. Скажите в чем это может быть дело??  Уже не знаю что и думать.
Вот привожу саму таблицу
Код
 `id` int(11) NOT NULL AUTO_INCREMENT,
  `path_map` varchar(100) NOT NULL,
  `name` varchar(50) NOT NULL DEFAULT '',
  `width` smallint(3) NOT NULL DEFAULT '0',
  `height` smallint(3) NOT NULL DEFAULT '0',
  `published` tinyint(1) NOT NULL DEFAULT '0',
  `show_image` tinyint(1) NOT NULL DEFAULT '0',
  `checked_out` int(1) NOT NULL DEFAULT '0',
  `checked_out_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  PRIMARY KEY (`id`)

*

Павел

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
На первый взгляд кавычки в запросах не помешали бы, поставь в админке максимальный уровень ошибок и увидишь
Нужно почитать про то, как правильно формировать запросу в базу данных
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Aleshka, у вас там опечатка, вместо #_atmap_country нужно #__atmap_country. Вы забыли поставить подчеркивание, Joomla заменяет это имя на josatmap_country, такой таблицы нет, и ничего не выполняется.

Для отладки, рекомендую сразу после вызова метода query, добавлять отображение ошибки:

Код: php
echo $this->_db->getErrorMsg();

Это касается вашего второго вопроса, а по первому сообщению, зачем в запросе делать выборку ВСЕХ записей по условию, если loadAssoc вернет вам только первую запись из выборки? Это излишняя нагрузка на БД.
*

Aleshka

  • Захожу иногда
  • 73
  • 2 / 0
Цитировать
На первый взгляд кавычки в запросах не помешали бы, поставь в админке максимальный уровень ошибок и увидишь
. По  поводу кавычек, а что есть разница если я поставлю запрос в двойные или одинарные? Да есть если в том случае если в двойных кавычках будет переменная тогда она будет преобразована в значение, если же  в одинарные то все значение будет приниматься как строка и переменные  не будут преобразовываться. Поставил я в админке максимальный уровень, но ничего это не дало. Да и думаю и не могло дать ответа!
Цитировать
Нужно почитать про то, как правильно формировать запросу в базу данных
. Павел, а что у меня неправильный запрос? Если да то в чем он неправильный?

Цитировать
у вас там опечатка, вместо #_atmap_country нужно #__atmap_country
. Да smart, Вы правы у меня там действительно опечатка, не заметил, но увы,
ошибочка была только в сообщении, а не в самой model, там все правильно два подчеркивания.
Smart,  поставил я вывод ошибки, но увы при выводе
Код
echo $this->_db->getErrorMsg();
. Я не получаю никакого сообщения! Но сейчас буду разбираться, спасибо за совет. 
Цитировать
зачем в запросе делать выборку ВСЕХ записей по условию, если loadAssoc вернет вам только первую запись из выборки?
Но у меня при данном условии должно выводить только одно значение, но мне интересно а как бы Вы посоветовали выводить результат? 
*

Aleshka

  • Захожу иногда
  • 73
  • 2 / 0
Да забыл сказать, если просто беру запрос который у меня есть и вставляю в командную строку самой БД, естественно заменив #_ на префикс БД, в моем случае это jos, то запрос прекрасно выполняется. И если честно  уже не знаю в чем дело!
*

Aleshka

  • Захожу иногда
  • 73
  • 2 / 0
Решил проблему, оказывается всему виной моя не внимательность. Я почему-то думал что запрос к БД выполняется
Код
методом setQuery
, но этот метод только подготавливает запрос, я же думал что он и выполняет запрос, а вот метод например loadAssoc возвращает данные. И для того чтобы выполнился запрос по обновлению таблицы достаточно написать было запрос и вызвать его через метод QuerySet(в моем понимании), а реально еще необходимо было вызвать следующий метод query после QuerySet. т.е запрос должен иметь следующий вид:
Код
$query="UPDATE #__atmap_country SET show_image=1 WHERE id=1";
$db->setQuery($query);
$this->_db->query();
Smart, спасибо за идею использовать метод getErrorMsg(), он и натолкнул меня на решение проблемы.
« Последнее редактирование: 26.04.2010, 01:55:11 от Aleshka »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Перенаправление запросов

Автор jumlach

Ответов: 0
Просмотров: 1203
Последний ответ 23.10.2013, 18:44:40
от jumlach
Последовательность плагинов на странице (content)

Автор Kovryga

Ответов: 1
Просмотров: 1233
Последний ответ 09.04.2013, 11:09:51
от Aleks_El_Dia
Как узнать количество запросов к БД?

Автор stardel

Ответов: 4
Просмотров: 4880
Последний ответ 09.04.2011, 01:12:35
от GDV
Joomla 1.5 сколько выдержит запросов одновременно ?

Автор DiLiBot

Ответов: 7
Просмотров: 1825
Последний ответ 25.01.2011, 17:42:16
от smart
как определить количество запросов к бд?

Автор Gorgeous92

Ответов: 1
Просмотров: 1419
Последний ответ 27.12.2010, 18:00:34
от SmokerMan