Плагин «Информационные карточки — добавление текста и мультимедиа в макеты карточек» для WordPress уязвим к сохраненным межсайтовым сценариям через параметр «btnUrl» в блоке информационных карточек во всех версиях до 2.0.7 включительно. Это связано с недостаточной проверкой входных данных в схемах URL-адресов, в частности с отсутствием фильтрации протоколов javascript:. render.php блока передает все атрибуты в формате JSON во внешний интерфейс через HTML-атрибут data-attributes с использованием esc_attr(wp_json_encode()), который предотвращает внедрение атрибутов HTML, но не проверяет протоколы URL в данных JSON. Затем клиентский view.js отображает значение btnUrl непосредственно как атрибут href в элементах привязки без какой-либо очистки протокола.
Это позволяет злоумышленникам, прошедшим проверку подлинности, с доступом на уровне участника и выше, внедрять javascript: URL-адреса, которые выполняют произвольные веб-скрипты, когда пользователь нажимает отображаемую ссылку на кнопку.
Показать оригинальное описание (EN)
The Info Cards – Add Text and Media in Card Layouts plugin for WordPress is vulnerable to Stored Cross-Site Scripting via the 'btnUrl' parameter within the Info Cards block in all versions up to, and including, 2.0.7. This is due to insufficient input validation on URL schemes, specifically the lack of javascript: protocol filtering. The block's render.php passes all attributes as JSON to the frontend via a data-attributes HTML attribute using esc_attr(wp_json_encode()), which prevents HTML attribute injection but does not validate URL protocols within the JSON data. The client-side view.js then renders the btnUrl value directly as an href attribute on anchor elements without any protocol sanitization. This makes it possible for authenticated attackers, with Contributor-level access and above, to inject javascript: URLs that execute arbitrary web scripts when a user clicks the rendered button link.
Характеристики атаки
Последствия
Строка CVSS v3.1