Плагин Blackhole for Bad Bots для WordPress уязвим к хранимым межсайтовым сценариям через HTTP-заголовок User-Agent во всех версиях до 3.8 включительно. Это происходит из-за недостаточной очистки входных данных и утечки выходных данных. Плагин использует sanitize_text_field() при захвате данных бота (который удаляет HTML-теги, но не экранирует HTML-объекты, такие как двойные кавычки), а затем сохраняет данные с помощью update_option().
Когда администратор просматривает страницу журнала Bad Bots, сохраненные данные выводятся непосредственно в атрибуты входных значений HTML (строки 75–83) без esc_attr() и в содержимое диапазона HTML без esc_html(). Это позволяет неаутентифицированным злоумышленникам внедрять произвольные веб-скрипты, которые выполняются, когда администратор просматривает страницу администрирования Blackhole Bad Bots.
Показать оригинальное описание (EN)
The Blackhole for Bad Bots plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the User-Agent HTTP header in all versions up to and including 3.8. This is due to insufficient input sanitization and output escaping. The plugin uses sanitize_text_field() when capturing bot data (which strips HTML tags but does not escape HTML entities like double quotes), then stores the data via update_option(). When an administrator views the Bad Bots log page, the stored data is output directly into HTML input value attributes (lines 75-83) without esc_attr() and into HTML span content without esc_html(). This makes it possible for unauthenticated attackers to inject arbitrary web scripts that execute when an administrator views the Blackhole Bad Bots admin page.
Характеристики атаки
Последствия
Строка CVSS v3.1