CVE-2025-69873
LOW2.9EPSS 0.01%ajv has ReDoS when using `$data` option
描述
ajv (Another JSON Schema Validator) through version 8.17.1 is vulnerable to Regular Expression Denial of Service (ReDoS) when the `$data` option is enabled. The pattern keyword accepts runtime data via JSON Pointer syntax (`$data` reference), which is passed directly to the JavaScript `RegExp()` constructor without validation. An attacker can inject a malicious regex pattern (e.g., `\"^(a|a)*$\"`) combined with crafted input to cause catastrophic backtracking. A 31-character payload causes approximately 44 seconds of CPU blocking, with each additional character doubling execution time. This enables complete denial of service with a single HTTP request against any API using ajv with `$data`: true for dynamic schema validation.
受影響套件(2)
- Debian/node-ajvfrom 0
- npm/ajv>= 7.0.0-alpha.0, < 8.18.0
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 4.0 | — | 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:P |
| osv | CVSS 3.1 | LOW2.9 | CVSS:3.1/AV:L/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:L |
參考連結(12)
- ADVISORYhttps://github.com/advisories/GHSA-2g4f-4pwh-qvx6
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2025-69873
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2025-69873
- PATCHhttps://github.com/ajv-validator/ajv
- WEBhttps://github.com/ajv-validator/ajv/commit/720a23fa453ffae8340e92c9b0fe886c54cfe0d5
- WEBhttps://github.com/ajv-validator/ajv/pull/2586
- WEBhttps://github.com/ajv-validator/ajv/pull/2588
- WEBhttps://github.com/ajv-validator/ajv/pull/2590
- WEBhttps://github.com/ajv-validator/ajv/releases/tag/v6.14.0
- WEBhttps://github.com/ajv-validator/ajv/releases/tag/v8.18.0
- WEBhttps://github.com/EthanKim88/ethan-cve-disclosures/blob/main/CVE-2025-69873-ajv-ReDoS.md
- WEBhttps://github.com/github/advisory-database/pull/6991