CVE-2024-29041
Description
Express.js minimalist web framework for node. Versions of Express.js prior to 4.19.0 and all pre-release alpha and beta versions of 5.0 are affected by an open redirect vulnerability using malformed URLs. When a user of Express performs a redirect using a user-provided URL Express performs an encode [using `encodeurl`](https://github.com/pillarjs/encodeurl) on the contents before passing it to the `location` header. This can cause malformed URLs to be evaluated in unexpected ways by common redirect allow list implementations in Express applications, leading to an Open Redirect via bypass of a properly implemented allow list. The main method impacted is `res.location()` but this is also called from within `res.redirect()`. The vulnerability is fixed in 4.19.2 and 5.0.0-beta.3.
CWE
- CWE-601 — CWE-601: URL Redirection to Untrusted Site ('Open Redirect')
- CWE-1286 — CWE-1286: Improper Validation of Syntactic Correctness of Input
Affected
- expressjs / express — v=>=4.14.0, <4.19.0 [affected]; v=>=5.0.0-alpha.1, <5.0.0-beta.3 [affected]
CVSS
- 3.1 score=6.1 severity=MEDIUM
CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N
References
- https://github.com/expressjs/express/security/advisories/GHSA-rv95-896h-c2vc x_refsource_CONFIRM
- https://github.com/koajs/koa/issues/1800 x_refsource_MISC
- https://github.com/expressjs/express/pull/5539 x_refsource_MISC
- https://github.com/expressjs/express/commit/0867302ddbde0e9463d0564fea5861feb708c2dd x_refsource_MISC
- https://github.com/expressjs/express/commit/0b746953c4bd8e377123527db11f9cd866e39f94 x_refsource_MISC
- https://expressjs.com/en/4x/api.html#res.location x_refsource_MISC
Source
cvelistV5-main/cves/2024/29xxx/CVE-2024-29041.json