Новости Joomla

Совет по Joomla: $db->getQuery(true) стал устаревшим

Совет по Joomla: $db->getQuery(true) стал устаревшим

👩‍💻 Совет по Joomla: $db->getQuery(true) стал устаревшим.Раньше при создании запросов в базу данных мы всегда получали объект запроса с помощью метода

getQuery(). Если передавался параметр
$new =
true, то получали новый запрос. Если без - последний.

use Joomla\CMS\Factory;$db = Factory::getContainer()->get('DatabaseDriver');$query = $db->getQuery(new: true);// и строим запрос
Под капот Joomla 4 вошёл Joomla Framework (PHP фреймворк а-ля Laravel, Yii и т.д.), а для Joomla 5 он обновился - версия 3.4.1 вышла 6 октября 2023г. В методе фреймворка есть примечание о том, что параметр
$new, который передавался в метод
getQuery() помечен как устаревший и будет удалён в версии фреймворка 4.0.
The parameter $new is deprecated and will be removed in 4.0, use %s::createQuery() instead.В Joomla 4 версия Joomla Framework была 2.x., в Joomla 5 - 3.x. Поэтому есть предположение, что с выходом Joomla 6 обновится и версия фреймворка - станет 4.0. Поэтому для получения объекта для новых запросов следует использовать метод
createQuery(). Он уже представлен в ядре и широко используется. При этом метод
getQuery() останется, но, скорее всего, будет выполнять функцию только геттера - получения текущего запроса.
@joomlafeed#joomla #php #разработка

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

cvgh

  • Захожу иногда
  • 56
  • 0 / 0
Попытался написать такое:
Цитировать
   $q="UPDATE jo_hello SET source='$_REQUEST[source]', $request WHERE id=$_REQUEST[func_id]";
    $db->setQuery($q);
, но обнаружил, что запись в БД не меняется. Если имя таблицы записать как #__hello, тоже не помогает. Что я делаю неправильно?
*

Lex

  • Завсегдатай
  • 1615
  • 274 / 1
$q="UPDATE jo_hello SET source='$_REQUEST[source]', $request WHERE id=$_REQUEST[func_id]";
$db->setQuery($q);
$db->query();
А вот это SET source='$_REQUEST[source]', $request WHERE id=$_REQUEST[func_id] прямой путь к sql иньекции
Жизнь заставила учиться.
В личке на вопросы не отвечаю.
*

cvgh

  • Захожу иногда
  • 56
  • 0 / 0
Ну а как быть? Использовать bind и store?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

php скрипт для вызова url адреса открытой страницы

Автор bigrash

Ответов: 10
Просмотров: 6232
Последний ответ 17.02.2024, 20:12:05
от Vastriet
Проблемы с правами на запись папок "logs и tmp"

Автор murich

Ответов: 42
Просмотров: 27358
Последний ответ 07.10.2021, 18:29:16
от Maxandrey
Вместо некоторых разделов стали отображаться пустые страницы

Автор ch

Ответов: 0
Просмотров: 1113
Последний ответ 04.12.2020, 15:07:27
от ch
Поиск статьи по url сайта в админке Joomla 1.5

Автор Tema

Ответов: 5
Просмотров: 1838
Последний ответ 14.08.2020, 07:16:44
от rsn
Страницы не прогружаются до конца

Автор HeroYukki

Ответов: 0
Просмотров: 1249
Последний ответ 11.09.2018, 21:12:00
от HeroYukki