VDB
EN
HIGH

GHSA-hqr9-c56f-3x7f

@angular/platform-server: Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')

상세

A Cross-Site Scripting (XSS) vulnerability exists in `@angular/platform-server`'s DOM emulation dependency (`domino`) when serializing the content of raw-text elements (such as `<script>`, `<style>`, and `<iframe>`).

`domino` supports escaping raw-text elements during serialization to prevent closing-tag breakout. However, a **Unicode index alignment bug** existed in this escaping logic.

In JavaScript, string lengths and character indices are calculated based on UTF-16 code units (where astral characters—such as emojis—occupy 2 code units / 4 bytes). If the bound dynamic text contained astral Unicode characters _before_ the closing tag (e.g. `</script>`, `</style>`, or `</iframe>`), the index offset calculation in `domino`'s replacement logic shifted.

This misalignment caused `domino` to fail to replace or escape the closing tag, leaving it raw and unescaped in the output HTML.

An attacker who controls the dynamic text can supply a payload containing both an astral Unicode character and a closing tag (e.g., `😀</iframe><script>alert(1)</script>`). When serialized on the server during SSR, the browser parses the unescaped closing tag, exits the raw-text context early, and executes the subsequent `<script>` block, leading to same-origin Cross-Site Scripting (XSS).

### Impact

This vulnerability allows an attacker to perform same-origin Cross-Site Scripting (XSS) attacks against any user visiting an SSR-rendered page that binds user-controlled data inside raw-text elements. This can lead to session hijacking, credentials theft, unauthorized actions on behalf of users, and defacement.

### Patched Versions

- 22.0.0-rc.2 - 21.2.16 - 20.3.24 - 19.2.25

### Workarounds

If you cannot immediately update your dependencies, you can:

- Avoid binding user-controlled values inside `<iframe>` or other raw-text elements. - Sanitize any user input placed inside raw-text elements to explicitly strip closing tags before passing it to the template.

이 버전이 영향받나요?

사용 중인 패키지 버전을 입력하면 즉시 평가합니다.

영향 패키지

npm / @angular/platform-server
최초 영향 버전: 22.0.0-next.0 수정 버전: 22.0.0-rc.2
수정 npm install @angular/platform-server@22.0.0-rc.2
npm / @angular/platform-server
최초 영향 버전: 21.0.0-next.0 수정 버전: 21.2.16
수정 npm install @angular/platform-server@21.2.16
npm / @angular/platform-server
최초 영향 버전: 20.0.0-next.0 수정 버전: 20.3.24
수정 npm install @angular/platform-server@20.3.24
npm / @angular/platform-server
최초 영향 버전: 19.0.0-next.0 수정 버전: 19.2.25
수정 npm install @angular/platform-server@19.2.25
npm / @angular/platform-server
최초 영향 버전: 0

No fixed version published yet for @angular/platform-server (npm). Pin to a known-safe version or switch to an alternative.

참고