Unhead — менеджер заголовков документов и шаблонов. До версии 2.1.11 проверка link.href в makeTagSafe (safe.ts) использовала метод String.includes(), чувствительный к регистру. Браузеры обрабатывают схемы URI без учета регистра. DATA:text/css,... — то же самое, что и data:text/css,... для браузера, но 'DATA:...'.includes('data:') возвращает false.
Злоумышленник может внедрить произвольный CSS для исправления пользовательского интерфейса или утечки данных с помощью селекторов атрибутов CSS с обратными вызовами фонового изображения. Эта уязвимость исправлена в версии 2.1.11.
Показать оригинальное описание (EN)
Unhead is a document head and template manager. Prior to 2.1.11, The link.href check in makeTagSafe (safe.ts) uses String.includes(), which is case-sensitive. Browsers treat URI schemes case-insensitively. DATA:text/css,... is the same as data:text/css,... to the browser, but 'DATA:...'.includes('data:') returns false. An attacker can inject arbitrary CSS for UI redressing or data exfiltration via CSS attribute selectors with background-image callbacks. This vulnerability is fixed in 2.1.11.
Характеристики атаки
Последствия
Строка CVSS v3.1
Тип уязвимости (CWE)
Уязвимые продукты 1
| Конфигурация | От (включительно) | До (исключительно) |
|---|---|---|
|
Unjs Unhead
cpe:2.3:a:unjs:unhead:*:*:*:*:*:*:*:*
|
— |
2.1.11
|