CVE-2026-31988

Source
https://cve.org/CVERecord?id=CVE-2026-31988
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-31988.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2026-31988
Aliases
Downstream
Related
Published
2026-03-11T23:16:00.530Z
Modified
2026-03-17T07:44:11.095842Z
Severity
  • 6.9 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:L/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X CVSS Calculator
Summary
[none]
Details

yauzl (aka Yet Another Unzip Library) version 3.2.0 for Node.js contains an off-by-one error in the NTFS extended timestamp extra field parser within the getLastModDate() function. The while loop condition checks cursor < data.length + 4 instead of cursor + 4 <= data.length, allowing readUInt16LE() to read past the buffer boundary. A remote attacker can cause a denial of service (process crash via ERROUTOF_RANGE exception) by sending a crafted zip file with a malformed NTFS extra field. This affects any Node.js application that processes zip file uploads and calls entry.getLastModDate() on parsed entries. Fixed in version 3.2.1.

References

Affected packages

Git / github.com/thejoshwolfe/yauzl

Affected ranges

Type
GIT
Repo
https://github.com/thejoshwolfe/yauzl
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Fixed

Affected versions

1.*
1.1.1
2.*
2.0.0
2.0.1
2.0.2
2.0.3
2.1.0
2.10.0
2.2.0
2.2.1
2.3.0
2.3.1
2.4.0
2.4.1
2.4.2
2.4.3
2.5.0
2.6.0
2.8.0
2.9.0
2.9.1
2.9.2
3.*
3.0.0
3.1.0
3.1.1
3.1.2
3.1.3
3.2.0

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2026-31988.json"