Блог разработчика 1С-Битрикс

Класс PostDecodeFilter в Bitrix

PostDecodeFilter — это специальный класс, предназначенный для автоматического декодирования данных, полученных из _POST. При добавлении его в цепочку фильтров запроса данные из формы будут преобразованы в удобный для дальнейшей обработки вид.

PostDecodeFilter в Bitrix

Назначение класса

В некоторых сценариях работы с формами или AJAX-запросами поля могут содержать закодированную информацию (например, JSON-строки или другие форматы). PostDecodeFilter позволяет автоматически декодировать такие данные прямо на этапе получения запроса, что упрощает дальнейшую логику обработки.

Методы класса

Метод: Возвращает массив декодированных данных, используя метод getPost().

filter()

Основной метод класса. Вызывается автоматически при использовании фильтра. Позволяет преобразовать входящие параметры _POST в уже декодированном виде. В большинстве случаев достаточно просто добавить фильтр и затем обращаться к данным стандартными методами запроса (например, через getPost()).

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

Для подключения и использования фильтра достаточно добавить его в контекст запроса приложения Bitrix:


use Bitrix\Main\Application;
use Bitrix\Main\Engine\ActionFilter\PostDecodeFilter;

// Получаем экземпляр приложения
$app = Application::getInstance();
$context = $app->getContext();
$request = $context->getRequest();

// Подключаем фильтр
$request->addFilter(new PostDecodeFilter());

// Теперь данные из $_POST будут автоматически декодированы
$postData = $request->getPost();
    

После добавления фильтра, при обращении к данным запроса через метод getPost(), вы получите уже «распакованные» значения. Это значительно удобнее, если, например, нужно работать со сложными структурами данных, которые были сериализованы или закодированы на стороне формы.

Когда использовать

  • При работе с формами, где часть данных (или все) может быть закодирована (например, JSON-данные).
  • При использовании AJAX-запросов, в которых данные передаются в формате, требующем декодирования.
  • В случаях, когда нужно упростить логику обработки входящих параметров, не разборивая вручную массивы или сложные структуры.

Заключение

PostDecodeFilter — полезный инструмент в арсенале Bitrix-разработчика. Он избавляет от необходимости вручную декодировать данные из _POST, делая код более чистым и понятным. При работе со сложными формами и AJAX-запросами его применение существенно облегчает жизнь и снижает вероятность ошибок при обработке данных.

Теги: PostDecodeFilter, декодирование данных, обработка форм, AJAX-запросы


Валерий Макеев
10.09.2025 13:06
Этот код подключает PostDecodeFilter в Bitrix и выводит декодированный JSON из поля формы user_data при POST-запросе, автоматически преобразуя строку в ассоциативный массив.
Код
<?php
require_once($_SERVER['DOCUMENT_ROOT'].'/bitrix/modules/main/include/prolog_before.php');

use Bitrix\Main\Application;
use Bitrix\Main\Engine\ActionFilter\PostDecodeFilter;

$request = Application::getInstance()->getContext()->getRequest();
$request->addFilter(new PostDecodeFilter());

if ($request->isPost()) {
    $decodedData = $request->getPost('user_data'); // автоматически декодирует, если это JSON-строка
    echo '<pre>'; print_r($decodedData); echo '</pre>';
}
?>
<form method="POST">
    <textarea name="user_data">{"name": "Иван", "age": 30}</textarea>
    <button type="submit">Отправить</button>
</form>

Стоимость услуг по разработке и сопровождению сайтов на 1C-Битрикс

Участие в проекте

привлечение в проект на part-time основе

от 30 000 рублей / неделя

Возможно участие в проекте на ежедневной основе, как разработчика. Занятость - до 20 часов в неделю
Минимальный срок - одна неделя.

* сумма фиксированная

Лечение сайтов от вирусов

восстановление сайта и подъем версии PHP

от 25 000 рублей
Лечение сайтов на решениях АСПРО и прочих.

* полный комплекс лечения проекта и закрытия дыр

Разработка корпоративного сайта

от 7 дней

от 40 000 рублей

Разработка сайта без системы оплаты заказов через корзину

* стоимость зависит от наличия верстки, использования готового решения и т.д.