Home

Description

UltraJSON is a fast JSON encoder and decoder written in pure C with bindings for Python 3.7+. Versions 5.4.0 through 5.11.0 contain an accumulating memory leak in JSON parsing large (outside of the range [-2^63, 2^64 - 1]) integers. The leaked memory is a copy of the string form of the integer plus an additional NULL byte. The leak occurs irrespective of whether the integer parses successfully or is rejected due to having more than sys.get_int_max_str_digits() digits, meaning that any sized leak per malicious JSON can be achieved provided that there is no limit on the overall size of the payload. Any service that calls ujson.load()/ujson.loads()/ujson.decode() on untrusted inputs is affected and vulnerable to denial of service attacks. This issue has been fixed in version 5.12.0.

PUBLISHED Reserved 2026-03-16 | Published 2026-03-20 | Updated 2026-03-20 | Assigner GitHub_M




HIGH: 7.5CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

Problem types

CWE-401: Missing Release of Memory after Effective Lifetime

Product status

>= 5.4.0, < 5.12.0
affected

References

github.com/...rajson/security/advisories/GHSA-wgvc-ghv9-3pmm

github.com/...ommit/4baeb950df780092bd3c89fc702a868e99a3a1d2

github.com/ultrajson/ultrajson/releases/tag/5.12.0

cve.org (CVE-2026-32874)

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

Download JSON