GHSA-58c5-g7wp-6w37
Angular is Vulnerable to XSRF Token Leakage via Protocol-Relative URLs in Angular HTTP Client
Details
The vulnerability is a **Credential Leak by App Logic** that leads to the **unauthorized disclosure of the Cross-Site Request Forgery (XSRF) token** to an attacker-controlled domain.
Angular's HttpClient has a built-in XSRF protection mechanism that works by checking if a request URL starts with a protocol (`http://` or `https://`) to determine if it is cross-origin. If the URL starts with protocol-relative URL (`//`), it is incorrectly treated as a same-origin request, and the XSRF token is automatically added to the `X-XSRF-TOKEN` header.
### Impact The token leakage completely bypasses Angular's built-in CSRF protection, allowing an attacker to capture the user's valid XSRF token. Once the token is obtained, the attacker can perform arbitrary Cross-Site Request Forgery (CSRF) attacks against the victim user's session.
### Attack Preconditions 1. The victim's Angular application must have **XSRF protection enabled**. 2. The attacker must be able to make the application send a state-changing HTTP request (e.g., `POST`) to a **protocol-relative URL** (e.g., `//attacker.com`) that they control.
### Patches - 19.2.16 - 20.3.14 - 21.0.1
### Workarounds Developers should avoid using protocol-relative URLs (URLs starting with `//`) in HttpClient requests. All backend communication URLs should be hardcoded as relative paths (starting with a single `/`) or fully qualified, trusted absolute URLs.
Are you affected?
Enter the version of the package you're using.
Affected packages
21.0.0-next.0 Fixed in: 21.0.1 npm install @angular/common@21.0.1 20.0.0-next.0 Fixed in: 20.3.14 npm install @angular/common@20.3.14 References
- https://github.com/angular/angular/security/advisories/GHSA-58c5-g7wp-6w37 [WEB]
- https://nvd.nist.gov/vuln/detail/CVE-2025-66035 [ADVISORY]
- https://github.com/angular/angular/commit/0276479e7d0e280e0f8d26fa567d3b7aa97a516f [WEB]
- https://github.com/angular/angular/commit/05fe6686a97fa0bcd3cf157805b3612033f975bc [WEB]
- https://github.com/angular/angular/commit/3240d856d942727372a705252f7c8c115394a41e [WEB]
- https://cert-portal.siemens.com/productcert/html/ssa-253495.html [WEB]
- https://cert-portal.siemens.com/productcert/html/ssa-485750.html [WEB]
- https://github.com/angular/angular [PACKAGE]
- https://github.com/angular/angular/releases/tag/19.2.16 [WEB]
- https://github.com/angular/angular/releases/tag/20.3.14 [WEB]
- https://github.com/angular/angular/releases/tag/21.0.1 [WEB]