Home

Description

Undici allows duplicate HTTP Content-Length headers when they are provided in an array with case-variant names (e.g., Content-Length and content-length). This produces malformed HTTP/1.1 requests with multiple conflicting Content-Length values on the wire. Who is impacted: * Applications using undici.request(), undici.Client, or similar low-level APIs with headers passed as flat arrays * Applications that accept user-controlled header names without case-normalization Potential consequences: * Denial of Service: Strict HTTP parsers (proxies, servers) will reject requests with duplicate Content-Length headers (400 Bad Request) * HTTP Request Smuggling: In deployments where an intermediary and backend interpret duplicate headers inconsistently (e.g., one uses the first value, the other uses the last), this can enable request smuggling attacks leading to ACL bypass, cache poisoning, or credential hijacking

PUBLISHED Reserved 2026-01-28 | Published 2026-03-12 | Updated 2026-03-12 | Assigner openjs




MEDIUM: 6.5CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:L

Problem types

CWE-444 Inconsistent interpretation of HTTP requests ('HTTP Request/Response smuggling')

Product status

Default status
unaffected

< 6.24.0; 7.0.0 < 7.24.0
affected

6.24.0: 7.24.0
unaffected

Credits

Matteo Collina remediation developer

Ulises Gascón remediation developer

References

github.com/...undici/security/advisories/GHSA-2mjp-6q6p-2qxm

www.rfc-editor.org/rfc/rfc9110.html

cwe.mitre.org/data/definitions/444.html

hackerone.com/reports/3556037

cna.openjsf.org/security-advisories.html

cve.org (CVE-2026-1525)

nvd.nist.gov (CVE-2026-1525)

Download JSON