Skip to content

serve-static vulnerable to template injection that can lead to XSS

Moderate severity GitHub Reviewed Published Sep 10, 2024 in expressjs/serve-static • Updated Sep 10, 2024

Package

npm serve-static (npm)

Affected versions

< 1.16.0
>= 2.0.0, < 2.1.0

Patched versions

1.16.0
2.1.0

Description

Impact

passing untrusted user input - even after sanitizing it - to redirect() may execute untrusted code

Patches

this issue is patched in serve-static 1.16.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/serve-static 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.045%
(16th percentile)

Weaknesses

CVE ID

CVE-2024-43800

GHSA ID

GHSA-cm22-4g7w-348p

Credits

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