CVE-2026-2707

MEDIUM CVSS 3.1: 6,4 EPSS 0.04%
Обновлено 11 марта 2026
WordPress
Параметр Значение
CVSS 6,4 (MEDIUM)
Тип уязвимости CWE-79 (Межсайтовый скриптинг (XSS))
Поставщик WordPress
Публичный эксплойт Нет

Плагин weForms для WordPress уязвим для хранимых межсайтовых сценариев через конечную точку отправки записей REST API во всех версиях до 1.6.27 включительно. Это связано с несогласованной очисткой входных данных между обработчиком AJAX внешнего интерфейса и конечной точкой REST API. Когда записи отправляются через REST API (`/wp-json/weforms/v1/forms/{id}/entries/`), метод `prepare_entry()` в `class-abstract-fields.php` получает объект WP_REST_Request как `$args`, минуя резервный `weforms_clean()`, который очищает данные `$_POST` для отправки через интерфейс.

Обработчик базового поля применяет только к значению `trim()`. Это позволяет злоумышленникам, прошедшим проверку подлинности, с доступом на уровне подписчика и выше, внедрять произвольные веб-скрипты в значения скрытых полей ввода формы через REST API, которые выполняются, когда администратор просматривает страницу записей формы, где данные отображаются с помощью директивы Vue.js `v-html` без экранирования.

Показать оригинальное описание (EN)

The weForms plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the REST API entry submission endpoint in all versions up to, and including, 1.6.27. This is due to inconsistent input sanitization between the frontend AJAX handler and the REST API endpoint. When entries are submitted via the REST API (`/wp-json/weforms/v1/forms/{id}/entries/`), the `prepare_entry()` method in `class-abstract-fields.php` receives the WP_REST_Request object as `$args`, bypassing the `weforms_clean()` fallback that sanitizes `$_POST` data for frontend submissions. The base field handler only applies `trim()` to the value. This makes it possible for authenticated attackers, with Subscriber-level access and above, to inject arbitrary web scripts into form entry hidden field values via the REST API that execute when an administrator views the form entries page, where data is rendered using a Vue.js `v-html` directive without escaping.

Характеристики атаки

Способ атаки
По сети
Атака возможна удалённо
Сложность
Низкая
Легко эксплуатировать
Нужны права
Низкие
Нужны базовые права
Участие пользователя
Не требуется
Не нужно действие пользователя

Последствия

Конфиденциальность
Низкое
Частичная утечка данных
Целостность
Низкое
Частичная модификация данных
Доступность
Нет
Нет нарушения работы

Строка CVSS v3.1