java.lang.Object
org.springframework.boot.configurationprocessor.json.JSONObject

public class JSONObject extends Object
A modifiable set of name/value mappings. Names are unique, non-null strings. Values may be any mix of JSONObjects, JSONArrays, Strings, Booleans, Integers, Longs, Doubles or NULL. Values may not be null, NaNs, infinities, or of any type not listed here.

This class can coerce values to another type when requested.

  • When the requested type is a boolean, strings will be coerced using a case-insensitive comparison to "true" and "false".
  • When the requested type is a double, other Number types will be coerced using doubleValue. Strings that can be coerced using Double.valueOf(String) will be.
  • When the requested type is an int, other Number types will be coerced using intValue. Strings that can be coerced using Double.valueOf(String) will be, and then cast to int.
  • When the requested type is a long, other Number types will be coerced using longValue. Strings that can be coerced using Double.valueOf(String) will be, and then cast to long. This two-step conversion is lossy for very large values. For example, the string "9223372036854775806" yields the long 9223372036854775807.
  • When the requested type is a String, other non-null values will be coerced using String.valueOf(Object). Although null cannot be coerced, the sentinel value NULL is coerced to the string "null".

This class can look up both mandatory and optional values:

  • Use getType() to retrieve a mandatory value. This fails with a JSONException if the requested name has no value or if the value cannot be coerced to the requested type.
  • Use optType() to retrieve an optional value. This returns a system- or user-supplied default if the requested name has no value or if the value cannot be coerced to the requested type.

Warning: this class represents null in two incompatible ways: the standard Java null reference, and the sentinel value NULL. In particular, calling put(name, null) removes the named entry from the object but put(name, JSONObject.NULL) stores an entry whose value is JSONObject.NULL.

Instances of this class are not thread safe. Although this class is nonfinal, it was not designed for inheritance and should not be subclassed. In particular, self-use by overrideable methods is not specified. See Effective Java Item 17, "Design and Document or inheritance or else prohibit it" for further information.

  • Field Summary

    Fields
    Modifier and Type
    Field
    Description
    static final Object
    A sentinel value used to explicitly define a name with no value.
  • Constructor Summary

    Constructors
    Constructor
    Description
    Creates a JSONObject with no name/value mappings.
    Creates a new JSONObject with name/value mappings from the JSON string.
    JSONObject(Map copyFrom)
    Creates a new JSONObject by copying all name/value mappings from the given map.
    JSONObject(JSONObject copyFrom, String[] names)
    Creates a new JSONObject by copying mappings for the listed names from the given object.
    Creates a new JSONObject with name/value mappings from the next object in the tokener.
  • Method Summary

    Modifier and Type
    Method
    Description
    accumulate(String name, Object value)
    Appends value to the array already mapped to name.
    get(String name)
    Returns the value mapped by name.
    boolean
    Returns the value mapped by name if it exists and is a boolean or can be coerced to a boolean.
    double
    Returns the value mapped by name if it exists and is a double or can be coerced to a double.
    int
    getInt(String name)
    Returns the value mapped by name if it exists and is an int or can be coerced to an int.
    Returns the value mapped by name if it exists and is a JSONArray.
    Returns the value mapped by name if it exists and is a JSONObject.
    long
    Returns the value mapped by name if it exists and is a long or can be coerced to a long.
    Returns the value mapped by name if it exists, coercing it if necessary.
    boolean
    has(String name)
    Returns true if this object has a mapping for name.
    boolean
    isNull(String name)
    Returns true if this object has no mapping for name or if it has a mapping whose value is NULL.
    Returns an iterator of the String names in this object.
    int
    Returns the number of name/value mappings in this object.
    Returns an array containing the string names in this object.
    static String
    Encodes the number as a JSON string.
    opt(String name)
    Returns the value mapped by name, or null if no such mapping exists.
    boolean
    Returns the value mapped by name if it exists and is a boolean or can be coerced to a boolean.
    boolean
    optBoolean(String name, boolean fallback)
    Returns the value mapped by name if it exists and is a boolean or can be coerced to a boolean.
    double
    Returns the value mapped by name if it exists and is a double or can be coerced to a double.
    double
    optDouble(String name, double fallback)
    Returns the value mapped by name if it exists and is a double or can be coerced to a double.
    int
    optInt(String name)
    Returns the value mapped by name if it exists and is an int or can be coerced to an int.
    int
    optInt(String name, int fallback)
    Returns the value mapped by name if it exists and is an int or can be coerced to an int.
    Returns the value mapped by name if it exists and is a JSONArray.
    Returns the value mapped by name if it exists and is a JSONObject.
    long
    Returns the value mapped by name if it exists and is a long or can be coerced to a long.
    long
    optLong(String name, long fallback)
    Returns the value mapped by name if it exists and is a long or can be coerced to a long.
    Returns the value mapped by name if it exists, coercing it if necessary.
    optString(String name, String fallback)
    Returns the value mapped by name if it exists, coercing it if necessary.
    put(String name, boolean value)
    Maps name to value, clobbering any existing name/value mapping with the same name.
    put(String name, double value)
    Maps name to value, clobbering any existing name/value mapping with the same name.
    put(String name, int value)
    Maps name to value, clobbering any existing name/value mapping with the same name.
    put(String name, long value)
    Maps name to value, clobbering any existing name/value mapping with the same name.
    put(String name, Object value)
    Maps name to value, clobbering any existing name/value mapping with the same name.
    putOpt(String name, Object value)
    Equivalent to put(name, value) when both parameters are non-null; does nothing otherwise.
    static String
    quote(String data)
    Encodes data as a JSON string.
    remove(String name)
    Removes the named mapping if it exists; does nothing otherwise.
    Returns an array with the values corresponding to names.
    Encodes this object as a compact JSON string, such as:
    toString(int indentSpaces)
    Encodes this object as a human-readable JSON string for debugging, such as:
    static Object
    Wraps the given object if necessary.

    Methods inherited from class java.lang.Object

    clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
  • Field Details

    • NULL

      public static final Object NULL
      A sentinel value used to explicitly define a name with no value. Unlike null, names with this value:

      This value violates the general contract of Object.equals(java.lang.Object) by returning true when compared to null. Its toString() method returns "null".

  • Constructor Details

    • JSONObject

      public JSONObject()
      Creates a JSONObject with no name/value mappings.
    • JSONObject

      public JSONObject(Map copyFrom)
      Creates a new JSONObject by copying all name/value mappings from the given map.
      Parameters:
      copyFrom - a map whose keys are of type String and whose values are of supported types.
      Throws:
      NullPointerException - if any of the map's keys are null.
    • JSONObject

      public JSONObject(JSONTokener readFrom) throws JSONException
      Creates a new JSONObject with name/value mappings from the next object in the tokener.
      Parameters:
      readFrom - a tokener whose nextValue() method will yield a JSONObject.
      Throws:
      JSONException - if the parse fails or doesn't yield a JSONObject.
    • JSONObject

      public JSONObject(String json) throws JSONException
      Creates a new JSONObject with name/value mappings from the JSON string.
      Parameters:
      json - a JSON-encoded string containing an object.
      Throws:
      JSONException - if the parse fails or doesn't yield a JSONObject.
    • JSONObject

      public JSONObject(JSONObject copyFrom, String[] names) throws JSONException
      Creates a new JSONObject by copying mappings for the listed names from the given object. Names that aren't present in copyFrom will be skipped.
      Parameters:
      copyFrom - the source
      names - the property names
      Throws:
      JSONException - if an error occurs
  • Method Details

    • length

      public int length()
      Returns the number of name/value mappings in this object.
      Returns:
      the number of name/value mappings in this object
    • put

      public JSONObject put(String name, boolean value) throws JSONException
      Maps name to value, clobbering any existing name/value mapping with the same name.
      Parameters:
      name - the name of the property
      value - the value of the property
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • put

      public JSONObject put(String name, double value) throws JSONException
      Maps name to value, clobbering any existing name/value mapping with the same name.
      Parameters:
      name - the name of the property
      value - a finite value. May not be NaNs or infinities.
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • put

      public JSONObject put(String name, int value) throws JSONException
      Maps name to value, clobbering any existing name/value mapping with the same name.
      Parameters:
      name - the name of the property
      value - the value of the property
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • put

      public JSONObject put(String name, long value) throws JSONException
      Maps name to value, clobbering any existing name/value mapping with the same name.
      Parameters:
      name - the name of the property
      value - the value of the property
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • put

      public JSONObject put(String name, Object value) throws JSONException
      Maps name to value, clobbering any existing name/value mapping with the same name. If the value is null, any existing mapping for name is removed.
      Parameters:
      name - the name of the property
      value - a JSONObject, JSONArray, String, Boolean, Integer, Long, Double, NULL, or null. May not be NaNs or infinities.
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • putOpt

      public JSONObject putOpt(String name, Object value) throws JSONException
      Equivalent to put(name, value) when both parameters are non-null; does nothing otherwise.
      Parameters:
      name - the name of the property
      value - the value of the property
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • accumulate

      public JSONObject accumulate(String name, Object value) throws JSONException
      Appends value to the array already mapped to name. If this object has no mapping for name, this inserts a new mapping. If the mapping exists but its value is not an array, the existing and new values are inserted in order into a new array which is itself mapped to name. In aggregate, this allows values to be added to a mapping one at a time.
      Parameters:
      name - the name of the property
      value - a JSONObject, JSONArray, String, Boolean, Integer, Long, Double, NULL or null. May not be NaNs or infinities.
      Returns:
      this object.
      Throws:
      JSONException - if an error occurs
    • remove

      public Object remove(String name)
      Removes the named mapping if it exists; does nothing otherwise.
      Parameters:
      name - the name of the property
      Returns:
      the value previously mapped by name, or null if there was no such mapping.
    • isNull

      public boolean isNull(String name)
      Returns true if this object has no mapping for name or if it has a mapping whose value is NULL.
      Parameters:
      name - the name of the property
      Returns:
      true if this object has no mapping for name
    • has

      public boolean has(String name)
      Returns true if this object has a mapping for name. The mapping may be NULL.
      Parameters:
      name - the name of the property
      Returns:
      true if this object has a mapping for name
    • get

      public Object get(String name) throws JSONException
      Returns the value mapped by name.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if no such mapping exists.
    • opt

      public Object opt(String name)
      Returns the value mapped by name, or null if no such mapping exists.
      Parameters:
      name - the name of the property
      Returns:
      the value or null
    • getBoolean

      public boolean getBoolean(String name) throws JSONException
      Returns the value mapped by name if it exists and is a boolean or can be coerced to a boolean.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if the mapping doesn't exist or cannot be coerced to a boolean.
    • optBoolean

      public boolean optBoolean(String name)
      Returns the value mapped by name if it exists and is a boolean or can be coerced to a boolean. Returns false otherwise.
      Parameters:
      name - the name of the property
      Returns:
      the value or null
    • optBoolean

      public boolean optBoolean(String name, boolean fallback)
      Returns the value mapped by name if it exists and is a boolean or can be coerced to a boolean. Returns fallback otherwise.
      Parameters:
      name - the name of the property
      fallback - a fallback value
      Returns:
      the value or fallback
    • getDouble

      public double getDouble(String name) throws JSONException
      Returns the value mapped by name if it exists and is a double or can be coerced to a double.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if the mapping doesn't exist or cannot be coerced to a double.
    • optDouble

      public double optDouble(String name)
      Returns the value mapped by name if it exists and is a double or can be coerced to a double. Returns NaN otherwise.
      Parameters:
      name - the name of the property
      Returns:
      the value or NaN
    • optDouble

      public double optDouble(String name, double fallback)
      Returns the value mapped by name if it exists and is a double or can be coerced to a double. Returns fallback otherwise.
      Parameters:
      name - the name of the property
      fallback - a fallback value
      Returns:
      the value or fallback
    • getInt

      public int getInt(String name) throws JSONException
      Returns the value mapped by name if it exists and is an int or can be coerced to an int.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if the mapping doesn't exist or cannot be coerced to an int.
    • optInt

      public int optInt(String name)
      Returns the value mapped by name if it exists and is an int or can be coerced to an int. Returns 0 otherwise.
      Parameters:
      name - the name of the property
      Returns:
      the value of 0
    • optInt

      public int optInt(String name, int fallback)
      Returns the value mapped by name if it exists and is an int or can be coerced to an int. Returns fallback otherwise.
      Parameters:
      name - the name of the property
      fallback - a fallback value
      Returns:
      the value or fallback
    • getLong

      public long getLong(String name) throws JSONException
      Returns the value mapped by name if it exists and is a long or can be coerced to a long. Note that JSON represents numbers as doubles, so this is lossy; use strings to transfer numbers over JSON.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if the mapping doesn't exist or cannot be coerced to a long.
    • optLong

      public long optLong(String name)
      Returns the value mapped by name if it exists and is a long or can be coerced to a long. Returns 0 otherwise. Note that JSON represents numbers as doubles, so this is lossy; use strings to transfer numbers via JSON.
      Parameters:
      name - the name of the property
      Returns:
      the value or 0L
    • optLong

      public long optLong(String name, long fallback)
      Returns the value mapped by name if it exists and is a long or can be coerced to a long. Returns fallback otherwise. Note that JSON represents numbers as doubles, so this is lossy; use strings to transfer numbers over JSON.
      Parameters:
      name - the name of the property
      fallback - a fallback value
      Returns:
      the value or fallback
    • getString

      public String getString(String name) throws JSONException
      Returns the value mapped by name if it exists, coercing it if necessary.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if no such mapping exists.
    • optString

      public String optString(String name)
      Returns the value mapped by name if it exists, coercing it if necessary. Returns the empty string if no such mapping exists.
      Parameters:
      name - the name of the property
      Returns:
      the value or an empty string
    • optString

      public String optString(String name, String fallback)
      Returns the value mapped by name if it exists, coercing it if necessary. Returns fallback if no such mapping exists.
      Parameters:
      name - the name of the property
      fallback - a fallback value
      Returns:
      the value or fallback
    • getJSONArray

      public JSONArray getJSONArray(String name) throws JSONException
      Returns the value mapped by name if it exists and is a JSONArray.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if the mapping doesn't exist or is not a JSONArray.
    • optJSONArray

      public JSONArray optJSONArray(String name)
      Returns the value mapped by name if it exists and is a JSONArray. Returns null otherwise.
      Parameters:
      name - the name of the property
      Returns:
      the value or null
    • getJSONObject

      public JSONObject getJSONObject(String name) throws JSONException
      Returns the value mapped by name if it exists and is a JSONObject.
      Parameters:
      name - the name of the property
      Returns:
      the value
      Throws:
      JSONException - if the mapping doesn't exist or is not a JSONObject.
    • optJSONObject

      public JSONObject optJSONObject(String name)
      Returns the value mapped by name if it exists and is a JSONObject. Returns null otherwise.
      Parameters:
      name - the name of the property
      Returns:
      the value or null
    • toJSONArray

      public JSONArray toJSONArray(JSONArray names)
      Returns an array with the values corresponding to names. The array contains null for names that aren't mapped. This method returns null if names is either null or empty.
      Parameters:
      names - the names of the properties
      Returns:
      the array
    • keys

      public Iterator keys()
      Returns an iterator of the String names in this object. The returned iterator supports remove, which will remove the corresponding mapping from this object. If this object is modified after the iterator is returned, the iterator's behavior is undefined. The order of the keys is undefined.
      Returns:
      the keys
    • names

      public JSONArray names()
      Returns an array containing the string names in this object. This method returns null if this object contains no mappings.
      Returns:
      the array
    • toString

      public String toString()
      Encodes this object as a compact JSON string, such as:
      {"query":"Pizza","locations":[94043,90210]}
      Overrides:
      toString in class Object
      Returns:
      a string representation of the object.
    • toString

      public String toString(int indentSpaces) throws JSONException
      Encodes this object as a human-readable JSON string for debugging, such as:
       {
           "query": "Pizza",
           "locations": [
               94043,
               90210
           ]
       }
      Parameters:
      indentSpaces - the number of spaces to indent for each level of nesting.
      Returns:
      a string representation of the object.
      Throws:
      JSONException - if an error occurs
    • numberToString

      public static String numberToString(Number number) throws JSONException
      Encodes the number as a JSON string.
      Parameters:
      number - a finite value. May not be NaNs or infinities.
      Returns:
      the encoded value
      Throws:
      JSONException - if an error occurs
    • quote

      public static String quote(String data)
      Encodes data as a JSON string. This applies quotes and any necessary character escaping.
      Parameters:
      data - the string to encode. Null will be interpreted as an empty string.
      Returns:
      the quoted value
    • wrap

      public static Object wrap(Object o)
      Wraps the given object if necessary.

      If the object is null or , returns NULL. If the object is a JSONArray or JSONObject, no wrapping is necessary. If the object is NULL, no wrapping is necessary. If the object is an array or Collection, returns an equivalent JSONArray. If the object is a Map, returns an equivalent JSONObject. If the object is a primitive wrapper type or String, returns the object. Otherwise if the object is from a java package, returns the result of toString. If wrapping fails, returns null.

      Parameters:
      o - the object to wrap
      Returns:
      the wrapped object