CVE-2024-29041
MEDIUM6.1EPSS 0.15%Express.js Open Redirect in malformed URLs
描述
### Impact Versions of Express.js prior to 4.19.2 and pre-release alpha and beta versions before 5.0.0-beta.3 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()`. ### Patches https://github.com/expressjs/express/commit/0867302ddbde0e9463d0564fea5861feb708c2dd https://github.com/expressjs/express/commit/0b746953c4bd8e377123527db11f9cd866e39f94 An initial fix went out with `[email protected]`, we then patched a feature regression in `4.19.1` and added improved handling for the bypass in `4.19.2`. ### Workarounds The fix for this involves pre-parsing the url string with either `require('node:url').parse` or `new URL`. These are steps you can take on your own before passing the user input string to `res.location` or `res.redirect`. ### Resources https://github.com/expressjs/express/pull/5539 https://github.com/koajs/koa/issues/1800 https://expressjs.com/en/4x/api.html#res.location
受影響套件(2)
- Debian/node-expressfrom 0
- npm/expressfrom 0, < 4.19.2
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM6.1 | CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N |
參考連結(9)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2024-29041
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2024-29041
- PATCHhttps://github.com/expressjs/express
- WEBhttps://expressjs.com/en/4x/api.html#res.location
- WEBhttps://github.com/expressjs/express/commit/0867302ddbde0e9463d0564fea5861feb708c2dd
- WEBhttps://github.com/expressjs/express/commit/0b746953c4bd8e377123527db11f9cd866e39f94
- WEBhttps://github.com/expressjs/express/pull/5539
- WEBhttps://github.com/expressjs/express/security/advisories/GHSA-rv95-896h-c2vc
- WEBhttps://github.com/koajs/koa/issues/1800