Skip to content

express vulnerable to XSS via response.redirect()

Moderate severity GitHub Reviewed Published Sep 10, 2024 in expressjs/express • Updated Sep 10, 2024

Package

npm express (npm)

Affected versions

< 4.20.0
>= 5.0.0-alpha.1, < 5.0.0

Patched versions

4.20.0
5.0.0

Description

Impact

In express <4.20.0, passing untrusted user input - even after sanitizing it - to response.redirect() may execute untrusted code

Patches

this issue is patched in express 4.20.0

Workarounds

users are encouraged to upgrade to the patched version of express, but otherwise can workaround this issue by making sure any untrusted inputs are safe, ideally by validating them against an explicit allowlist

Details

successful exploitation of this vector requires the following:

  1. The attacker MUST control the input to response.redirect()
  2. express MUST NOT redirect before the template appears
  3. the browser MUST NOT complete redirection before:
  4. the user MUST click on the link in the template

References

@ctcpip ctcpip published to expressjs/express Sep 10, 2024
Published by the National Vulnerability Database Sep 10, 2024
Published to the GitHub Advisory Database Sep 10, 2024
Reviewed Sep 10, 2024
Last updated Sep 10, 2024

Severity

Moderate

EPSS score

0.043%
(10th percentile)

Weaknesses

CVE ID

CVE-2024-43796

GHSA ID

GHSA-qw6h-vgh9-j6wx

Source code

Credits

Loading Checking history
See something to contribute? Suggest improvements for this vulnerability.