Angular SSR — это серверный инструмент рендеринга для приложений Angular. Уязвимость Open Redirect существует во внутренней логике обработки URL-адресов в версиях ветки 19.x до 19.2.21, ветки 20.x до 20.3.17 и ветки 21.x до 21.1.5 и 21.2.0-rc.1. Эта логика нормализует сегменты URL-адресов, удаляя начальные косые черты; однако он удаляет только одну косую черту.
Когда приложение Angular SSR развертывается за прокси-сервером, который передает заголовок X-Forwarded-Prefix, злоумышленник может предоставить значение, начинающееся с трех косых черт. Эта уязвимость позволяет злоумышленникам проводить масштабный фишинг и SEO-взлом. Чтобы быть уязвимым, приложение должно использовать Angular SSR, приложение должно иметь маршруты, выполняющие внутренние перенаправления, инфраструктура (обратный прокси/CDN) должна передавать заголовок X-Forwarded-Prefix процессу SSR без очистки, а кеш не должен изменяться в заголовке X-Forwarded-Prefix.
Версии 21.2.0-rc.1, 21.1.5, 20.3.17 и 19.2.21 содержат исправление. До тех пор, пока патч не будет применен, разработчикам следует очистить заголовок X-Forwarded-Prefix в файле server.ts перед тем, как движок Angular обработает запрос.
Показать оригинальное описание (EN)
The Angular SSR is a server-rise rendering tool for Angular applications. An Open Redirect vulnerability exists in the internal URL processing logic in versions on the 19.x branch prior to 19.2.21, the 20.x branch prior to 20.3.17, and the 21.x branch prior to 21.1.5 and 21.2.0-rc.1. The logic normalizes URL segments by stripping leading slashes; however, it only removes a single leading slash. When an Angular SSR application is deployed behind a proxy that passes the `X-Forwarded-Prefix` header, an attacker can provide a value starting with three slashes. This vulnerability allows attackers to conduct large-scale phishing and SEO hijacking. In order to be vulnerable, the application must use Angular SSR, the application must have routes that perform internal redirects, the infrastructure (Reverse Proxy/CDN) must pass the `X-Forwarded-Prefix` header to the SSR process without sanitization, and the cache must not vary on the `X-Forwarded-Prefix` header. Versions 21.2.0-rc.1, 21.1.5, 20.3.17, and 19.2.21 contain a patch. Until the patch is applied, developers should sanitize the `X-Forwarded-Prefix` header in their`server.ts` before the Angular engine processes the request.
Характеристики атаки
Последствия
Строка CVSS v4.0