CVE-2026-3368

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

Плагин Injection Guard для WordPress уязвим к хранимым межсайтовым сценариям через вредоносные имена параметров запроса во всех версиях до 1.2.9 включительно. Это связано с недостаточной очисткой входных данных в функции sanitize_ig_data(), которая очищает только значения массива, но не ключи массива, а также с отсутствием экранирования вывода в шаблоне ig_settings.php, где сохраненные ключи параметров отображаются непосредственно в HTML. Когда делается запрос на сайт, плагин захватывает строку запроса через $_SERVER['QUERY_STRING'], применяет esc_url_raw() (который сохраняет специальные символы в кодировке URL, такие как %22, %3E, %3C), затем передает ее в parse_str(), который URL-декодирует строку, в результате чего в ключах массива декодируется HTML/JavaScript.

Эти ключи сохраняются через update_option('ig_requests_log') и позже отображаются без esc_html() или esc_attr() на странице журнала администратора. Это позволяет неаутентифицированным злоумышленникам внедрять произвольные веб-скрипты на страницу журнала администратора, которые выполняются всякий раз, когда администратор просматривает интерфейс журнала Injection Guard.

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

The Injection Guard plugin for WordPress is vulnerable to Stored Cross-Site Scripting via malicious query parameter names in all versions up to and including 1.2.9. This is due to insufficient input sanitization in the sanitize_ig_data() function which only sanitizes array values but not array keys, combined with missing output escaping in the ig_settings.php template where stored parameter keys are echoed directly into HTML. When a request is made to the site, the plugin captures the query string via $_SERVER['QUERY_STRING'], applies esc_url_raw() (which preserves URL-encoded special characters like %22, %3E, %3C), then passes it to parse_str() which URL-decodes the string, resulting in decoded HTML/JavaScript in the array keys. These keys are stored via update_option('ig_requests_log') and later rendered without esc_html() or esc_attr() on the admin log page. This makes it possible for unauthenticated attackers to inject arbitrary web scripts in the admin log page that execute whenever an administrator views the Injection Guard log interface.

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

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

Последствия

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

Строка CVSS v3.1

Ссылки 18

https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/guard.php…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/guard.php…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/guard.php…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/guard.php…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/guard.php…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/ig_settin…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/ig_settin…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/tags/1.2.8/ig_settin…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/guard.php#L105
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/guard.php#L153
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/guard.php#L49
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/guard.php#L8
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/guard.php#L94
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/ig_settings.ph…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/ig_settings.ph…
security@wordfence.com
https://plugins.trac.wordpress.org/browser/injection-guard/trunk/ig_settings.ph…
security@wordfence.com
https://plugins.trac.wordpress.org/changeset?sfp_email=&sfph_mail=&reponame=&ol…
security@wordfence.com
https://www.wordfence.com/threat-intel/vulnerabilities/id/15d9817c-910d-4ce1-a5…
security@wordfence.com