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

Snip

  • Захожу иногда
  • 236
  • 14 / 1
Ребята, в БД в таблице где все посты (а там их 1400 штук) абсолютно в каждой теме прописалась вот такая зараза "<script src='https://dock.lovegreenpencils.ga/m.js?n=ns1' type='text/javascript'></script>".

Сама суть в том, что любая тема, даже главная страница, на ней приветственный текст и в конце вставлен этот заразный код.
Помогите советом. Как правильно прописать SQL запрос чтобы удалить этот текст из всех тем с постами из БД?
*

AlexB

  • Завсегдатай
  • 1973
  • 54 / 2
Re: Нужно вычистить заразу из БД
« Ответ #1 : 15.12.2020, 11:09:23 »
экспортируйте таблицу
и массовой заменой скрипта на пустое место


но не факт что оно вам поможет
это надо искать откуда оно тянется
*

fbr

  • Завсегдатай
  • 1663
  • 206 / 7
Re: Нужно вычистить заразу из БД
« Ответ #2 : 15.12.2020, 11:22:11 »
Для замены в БД я часто пользуюсь вот этим:
https://regularlabs.com/extensions/dbreplacer
*

rsn

  • Давно я тут
  • 520
  • 34 / 3
Re: Нужно вычистить заразу из БД
« Ответ #3 : 15.12.2020, 12:12:11 »
А как насчет одного SQL запросика с SET REPLACE ?  ^-^

Простой пример:
Код
UPDATE `table_name` SET `field_name`= REPLACE(`field_name`, '&', '-');
Возможно, будет интересно: Интеграция с Ozon
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
Re: Нужно вычистить заразу из БД
« Ответ #4 : 15.12.2020, 12:15:50 »
скачать таблицу и в редакторе удалить JavaScript
*

wishlight

  • Гуру
  • 5053
  • 314 / 1
  • От 300 руб быстрый хостинг. Сервера.
Re: Нужно вычистить заразу из БД
« Ответ #5 : 15.12.2020, 15:51:50 »
Для замены в БД я часто пользуюсь вот этим:
https://regularlabs.com/extensions/dbreplacer
Для удобной замены кстати сойдет. А вот дыры залатать надо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться