Class JSONObject
- java.lang.Object
-
- com.github.openjson.JSONObject
-
public class JSONObject extends Object
A modifiable set of name/value mappings. Names are unique, non-null strings. Values may be any mix ofJSONObjects,JSONArrays, Strings, Booleans, Integers, Longs, Doubles orNULL. Values may not benull,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
Numbertypes will be coerced usingdoubleValue. Strings that can be coerced usingDouble.valueOf(String)will be. - When the requested type is an int, other
Numbertypes will be coerced usingintValue. Strings that can be coerced usingDouble.valueOf(String)will be, and then cast to int. - When the requested type is a long, other
Numbertypes will be coerced usinglongValue. Strings that can be coerced usingDouble.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 valueNULLis 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 aJSONExceptionif 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
nullreference, and the sentinel valueNULL. In particular, callingput(name, null)removes the named entry from the object butput(name, JSONObject.NULL)stores an entry whose value isJSONObject.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.
-
-
Constructor Summary
Constructors Constructor Description JSONObject()Creates aJSONObjectwith no name/value mappings.JSONObject(JSONObject copyFrom, String[] names)Creates a newJSONObjectby copying mappings for the listed names from the given object.JSONObject(JSONTokener readFrom)Creates a newJSONObjectwith name/value mappings from the next object in the tokener.JSONObject(Object bean)Creates a json object from a beanJSONObject(String json)Creates a newJSONObjectwith name/value mappings from the JSON string.JSONObject(Map copyFrom)Creates a newJSONObjectby copying all name/value mappings from the given map.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description JSONObjectaccumulate(String name, Object value)Appendsvalueto the array already mapped toname.JSONObjectappend(String name, Object value)Appends values to the array mapped toname.protected voidencode(JSONStringer stringer)Encodes this object usingJSONStringerprovidedObjectget(String name)Returns the value mapped byname, or throws if no such mapping exists.booleangetBoolean(String name)Returns the value mapped bynameif it exists and is a boolean or can be coerced to a boolean, or throws otherwise.doublegetDouble(String name)Returns the value mapped bynameif it exists and is a double or can be coerced to a double, or throws otherwise.intgetInt(String name)Returns the value mapped bynameif it exists and is an int or can be coerced to an int, or throws otherwise.JSONArraygetJSONArray(String name)Returns the value mapped bynameif it exists and is aJSONArray, or throws otherwise.JSONObjectgetJSONObject(String name)Returns the value mapped bynameif it exists and is aJSONObject, or throws otherwise.longgetLong(String name)Returns the value mapped bynameif it exists and is a long or can be coerced to a long, or throws otherwise.static String[]getNames(JSONObject x)StringgetString(String name)Returns the value mapped bynameif it exists, coercing it if necessary, or throws if no such mapping exists.booleanhas(String name)Returns true if this object has a mapping forname.booleanisNull(String name)Returns true if this object has no mapping fornameor if it has a mapping whose value isNULL.Iterator<String>keys()Returns an iterator of theStringnames in this object.Set<String>keySet()Returns the set ofStringnames in this object.intlength()Returns the number of name/value mappings in this object.JSONArraynames()Returns an array containing the string names in this object.static StringnumberToString(Number number)Encodes the number as a JSON string.static Map<String,Object>objectAsMap(Object bean)Creates a name-value map from a beanObjectopt(String name)Returns the value mapped byname, or null if no such mapping exists.booleanoptBoolean(String name)Returns the value mapped bynameif it exists and is a boolean or can be coerced to a boolean, or false otherwise.booleanoptBoolean(String name, boolean fallback)Returns the value mapped bynameif it exists and is a boolean or can be coerced to a boolean, orfallbackotherwise.doubleoptDouble(String name)Returns the value mapped bynameif it exists and is a double or can be coerced to a double, orNaNotherwise.doubleoptDouble(String name, double fallback)Returns the value mapped bynameif it exists and is a double or can be coerced to a double, orfallbackotherwise.intoptInt(String name)Returns the value mapped bynameif it exists and is an int or can be coerced to an int, or 0 otherwise.intoptInt(String name, int fallback)Returns the value mapped bynameif it exists and is an int or can be coerced to an int, orfallbackotherwise.JSONArrayoptJSONArray(String name)Returns the value mapped bynameif it exists and is aJSONArray, or null otherwise.JSONObjectoptJSONObject(String name)Returns the value mapped bynameif it exists and is aJSONObject, or null otherwise.longoptLong(String name)Returns the value mapped bynameif it exists and is a long or can be coerced to a long, or 0 otherwise.longoptLong(String name, long fallback)Returns the value mapped bynameif it exists and is a long or can be coerced to a long, orfallbackotherwise.StringoptString(String name)Returns the value mapped bynameif it exists, coercing it if necessary, or the empty string if no such mapping exists.StringoptString(String name, String fallback)Returns the value mapped bynameif it exists, coercing it if necessary, orfallbackif no such mapping exists.JSONObjectput(String name, boolean value)Mapsnametovalue, clobbering any existing name/value mapping with the same name.JSONObjectput(String name, double value)Mapsnametovalue, clobbering any existing name/value mapping with the same name.JSONObjectput(String name, int value)Mapsnametovalue, clobbering any existing name/value mapping with the same name.JSONObjectput(String name, long value)Mapsnametovalue, clobbering any existing name/value mapping with the same name.JSONObjectput(String name, Object value)Mapsnametovalue, clobbering any existing name/value mapping with the same name.JSONObjectputOpt(String name, Object value)Equivalent toput(name, value)when both parameters are non-null; does nothing otherwise.static Stringquote(String data)Encodesdataas a JSON string.Objectremove(String name)Removes the named mapping if it exists; does nothing otherwise.JSONArraytoJSONArray(JSONArray names)Returns an array with the values corresponding tonames.StringtoString()Encodes this object as a compact JSON string, such as:StringtoString(int indentSpaces)Encodes this object as a human readable JSON string for debugging, such as:StringtoString(JSONStringer stringer)Encodes this object usingJSONStringerprovidedstatic Objectwrap(Object o)Wraps the given object if necessary.
-
-
-
Field Detail
-
NULL
public static final Object NULL
A sentinel value used to explicitly define a name with no value. Unlikenull, names with this value:- show up in the
names()array - show up in the
keys()iterator - return
trueforhas(String) - do not throw on
get(String) - are included in the encoded JSON string.
This value violates the general contract of
Object.equals(java.lang.Object)by returning true when compared tonull. ItstoString()method returns "null". - show up in the
-
-
Constructor Detail
-
JSONObject
public JSONObject()
Creates aJSONObjectwith no name/value mappings.
-
JSONObject
public JSONObject(Map copyFrom)
Creates a newJSONObjectby copying all name/value mappings from the given map.- Parameters:
copyFrom- a map whose keys are of typeStringand 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 newJSONObjectwith name/value mappings from the next object in the tokener.- Parameters:
readFrom- a tokener whose nextValue() method will yield aJSONObject.- Throws:
JSONException- if the parse fails or doesn't yield aJSONObject.
-
JSONObject
public JSONObject(String json) throws JSONException
Creates a newJSONObjectwith 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 aJSONObject.
-
JSONObject
public JSONObject(JSONObject copyFrom, String[] names) throws JSONException
Creates a newJSONObjectby copying mappings for the listed names from the given object. Names that aren't present incopyFromwill be skipped.- Parameters:
copyFrom- The source object.names- The names of the fields to copy.- Throws:
JSONException- On internal errors. Shouldn't happen.
-
JSONObject
public JSONObject(Object bean) throws JSONException
Creates a json object from a bean- Parameters:
bean- the bean to create the json object from- Throws:
JSONException- If there is an exception while reading the bean
-
-
Method Detail
-
objectAsMap
public static Map<String,Object> objectAsMap(Object bean) throws JSONException
Creates a name-value map from a bean- Parameters:
bean- the bean to create the map from- Returns:
- name-value map representing the bean
- Throws:
JSONException- If there is an exception while reading the bean
-
getNames
public static String[] getNames(JSONObject x)
-
length
public int length()
Returns the number of name/value mappings in this object.- Returns:
- the length of this.
-
put
public JSONObject put(String name, boolean value) throws JSONException
Mapsnametovalue, clobbering any existing name/value mapping with the same name.- Parameters:
name- The name of the value to insert.value- The value to insert.- Returns:
- this object.
- Throws:
JSONException- Should not be possible.
-
put
public JSONObject put(String name, double value) throws JSONException
Mapsnametovalue, clobbering any existing name/value mapping with the same name.- Parameters:
name- The name for the new value.value- a finite value. May not beNaNsorinfinities.- Returns:
- this object.
- Throws:
JSONException- if value is NaN or infinite.
-
put
public JSONObject put(String name, int value) throws JSONException
Mapsnametovalue, clobbering any existing name/value mapping with the same name.- Parameters:
name- The name for the new value.value- The new value.- Returns:
- this object.
- Throws:
JSONException- Should not be possible.
-
put
public JSONObject put(String name, long value) throws JSONException
Mapsnametovalue, clobbering any existing name/value mapping with the same name.- Parameters:
name- The name of the new value.value- The new value to insert.- Returns:
- this object.
- Throws:
JSONException- Should not be possible.
-
put
public JSONObject put(String name, Object value) throws JSONException
Mapsnametovalue, clobbering any existing name/value mapping with the same name. If the value isnull, any existing mapping fornameis removed.- Parameters:
name- The name of the new value.value- aJSONObject,JSONArray, String, Boolean, Integer, Long, Double,NULL, ornull. May not beNaNsorinfinities. If value is Map or Collection the value is wrapped using corresponding JSONObject(map) or JSONArray(collection) object. This behavior is considered unsafe and is added for compatibility with original 'org.json' package only.- Returns:
- this object.
- Throws:
JSONException- if the value is an invalid double (infinite or NaN).
-
putOpt
public JSONObject putOpt(String name, Object value) throws JSONException
Equivalent toput(name, value)when both parameters are non-null; does nothing otherwise.- Parameters:
name- The name of the value to insert.value- The value to insert.- Returns:
- this object.
- Throws:
JSONException- if the value is an invalid double (infinite or NaN).
-
accumulate
public JSONObject accumulate(String name, Object value) throws JSONException
Appendsvalueto the array already mapped toname. If this object has no mapping forname, 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 toname. In aggregate, this allows values to be added to a mapping one at a time. Note thatappend(String, Object)provides better semantics. In particular, the mapping fornamewill always be aJSONArray. Usingaccumulatewill result in either aJSONArrayor a mapping whose type is the type ofvaluedepending on the number of calls to it.- Parameters:
name- The name of the field to change.value- aJSONObject,JSONArray, String, Boolean, Integer, Long, Double,NULLor null. May not beNaNsorinfinities.- Returns:
- this object after mutation.
- Throws:
JSONException- If the object being added is an invalid number.
-
append
public JSONObject append(String name, Object value) throws JSONException
Appends values to the array mapped toname. A newJSONArraymapping fornamewill be inserted if no mapping exists. If the existing mapping fornameis not aJSONArray, aJSONExceptionwill be thrown.- Parameters:
name- The name of the array to which the value should be appended.value- The value to append.- Returns:
- this object.
- Throws:
JSONException- ifnameisnullor if the mapping fornameis non-null and is not aJSONArray.
-
remove
public Object remove(String name)
Removes the named mapping if it exists; does nothing otherwise.- Parameters:
name- The name of the mapping to remove.- 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 fornameor if it has a mapping whose value isNULL.- Parameters:
name- The name of the value to check on.- Returns:
- true if the field doesn't exist or is null.
-
has
public boolean has(String name)
Returns true if this object has a mapping forname. The mapping may beNULL.- Parameters:
name- The name of the value to check on.- Returns:
- true if this object has a field named
name
-
get
public Object get(String name) throws JSONException
Returns the value mapped byname, or throws if no such mapping exists.- Parameters:
name- The name of the value to get.- Returns:
- The value.
- Throws:
JSONException- if no such mapping exists.
-
opt
public Object opt(String name)
Returns the value mapped byname, or null if no such mapping exists.- Parameters:
name- The name of the value to get.- Returns:
- The value.
-
getBoolean
public boolean getBoolean(String name) throws JSONException
Returns the value mapped bynameif it exists and is a boolean or can be coerced to a boolean, or throws otherwise.- Parameters:
name- The name of the field we want.- Returns:
- The selected value if it exists.
- 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 bynameif it exists and is a boolean or can be coerced to a boolean, or false otherwise.- Parameters:
name- The name of the field we want.- Returns:
- The selected value if it exists.
-
optBoolean
public boolean optBoolean(String name, boolean fallback)
Returns the value mapped bynameif it exists and is a boolean or can be coerced to a boolean, orfallbackotherwise.- Parameters:
name- The name of the field we want.fallback- The value to return if the field isn't there.- Returns:
- The selected value or the fallback.
-
getDouble
public double getDouble(String name) throws JSONException
Returns the value mapped bynameif it exists and is a double or can be coerced to a double, or throws otherwise.- Parameters:
name- The name of the field we want.- Returns:
- The selected value if it exists.
- 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 bynameif it exists and is a double or can be coerced to a double, orNaNotherwise.- Parameters:
name- The name of the field we want.- Returns:
- The selected value if it exists.
-
optDouble
public double optDouble(String name, double fallback)
Returns the value mapped bynameif it exists and is a double or can be coerced to a double, orfallbackotherwise.- Parameters:
name- The name of the field we want.fallback- The value to return if the field isn't there.- Returns:
- The selected value or the fallback.
-
getInt
public int getInt(String name) throws JSONException
Returns the value mapped bynameif it exists and is an int or can be coerced to an int, or throws otherwise.- Parameters:
name- The name of the field we want.- Returns:
- The selected value if it exists.
- 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 bynameif it exists and is an int or can be coerced to an int, or 0 otherwise.- Parameters:
name- The name of the field we want.- Returns:
- The selected value if it exists.
-
optInt
public int optInt(String name, int fallback)
Returns the value mapped bynameif it exists and is an int or can be coerced to an int, orfallbackotherwise.- Parameters:
name- The name of the field we want.fallback- The value to return if the field isn't there.- Returns:
- The selected value or the fallback.
-
getLong
public long getLong(String name) throws JSONException
Returns the value mapped bynameif it exists and is a long or can be coerced to a long, or throws otherwise. Note that JSON represents numbers as doubles, so this is lossy; use strings to transfer numbers via JSON without loss.- Parameters:
name- The name of the field that we want.- Returns:
- The value of the field.
- 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 bynameif it exists and is a long or can be coerced to a long, or 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 field we want.- Returns:
- The selected value.
-
optLong
public long optLong(String name, long fallback)
Returns the value mapped bynameif it exists and is a long or can be coerced to a long, orfallbackotherwise. Note that JSON represents numbers as doubles, so this is lossy; use strings to transfer numbers via JSON.- Parameters:
name- The name of the field we want.fallback- The value to return if the field isn't there.- Returns:
- The selected value or the fallback.
-
getString
public String getString(String name) throws JSONException
Returns the value mapped bynameif it exists, coercing it if necessary, or throws if no such mapping exists.- Parameters:
name- The name of the field we want.- Returns:
- The value of the field.
- Throws:
JSONException- if no such mapping exists.
-
optString
public String optString(String name)
Returns the value mapped bynameif it exists, coercing it if necessary, or the empty string if no such mapping exists.- Parameters:
name- The name of the field we want.- Returns:
- The value of the field.
-
optString
public String optString(String name, String fallback)
Returns the value mapped bynameif it exists, coercing it if necessary, orfallbackif no such mapping exists.- Parameters:
name- The name of the field that we want.fallback- The value to return if the field doesn't exist.- Returns:
- The value of the field or fallback.
-
getJSONArray
public JSONArray getJSONArray(String name) throws JSONException
Returns the value mapped bynameif it exists and is aJSONArray, or throws otherwise.- Parameters:
name- The field we want to get.- Returns:
- The value of the field (if it is a JSONArray.
- Throws:
JSONException- if the mapping doesn't exist or is not aJSONArray.
-
optJSONArray
public JSONArray optJSONArray(String name)
Returns the value mapped bynameif it exists and is aJSONArray, or null otherwise.- Parameters:
name- The name of the field we want.- Returns:
- The value of the specified field (assuming it is a JSNOArray
-
getJSONObject
public JSONObject getJSONObject(String name) throws JSONException
Returns the value mapped bynameif it exists and is aJSONObject, or throws otherwise.- Parameters:
name- The name of the field that we want.- Returns:
- a specified field value (if it is a JSONObject)
- Throws:
JSONException- if the mapping doesn't exist or is not aJSONObject.
-
optJSONObject
public JSONObject optJSONObject(String name)
Returns the value mapped bynameif it exists and is aJSONObject, or null otherwise.- Parameters:
name- The name of the value we want.- Returns:
- The specified value.
-
toJSONArray
public JSONArray toJSONArray(JSONArray names) throws JSONException
Returns an array with the values corresponding tonames. The array contains null for names that aren't mapped. This method returns null ifnamesis either null or empty.- Parameters:
names- The names of the fields that we want the values for.- Returns:
- The selected values.
- Throws:
JSONException- On internal errors. Shouldn't happen.
-
keys
public Iterator<String> keys()
Returns an iterator of theStringnames in this object. The returned iterator supportsremove, 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:
- an iterator over the keys.
-
keySet
public Set<String> keySet()
Returns the set ofStringnames in this object. The returned set is a view of the keys in this object.Set.remove(Object)will remove the corresponding mapping from this object and set iterator behaviour is undefined if this object is modified after it is returned. Seekeys().- Returns:
- The names in this object.
-
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 names.
-
toString
public String toString()
Encodes this object as a compact JSON string, such as:{"query":"Pizza","locations":[94043,90210]}Note 1: this method will not output any fields with 'null' value. OverrideJSONStringer.entry(java.util.Map.Entry<java.lang.String, java.lang.Object>)method to have nulls printed. Note 2: this method will suppress any internal exceptions. UsetoString(JSONStringer)method directly to handle exceptions manually.
-
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:
- The string containing the pretty form of this.
- Throws:
JSONException- On internal errors. Shouldn't happen.
-
toString
public String toString(JSONStringer stringer) throws JSONException
Encodes this object usingJSONStringerprovided- Parameters:
stringer- -JSONStringerto be used for serialization- Returns:
- The string representation of this.
- Throws:
JSONException- On internal errors. Shouldn't happen.
-
encode
protected void encode(JSONStringer stringer) throws JSONException
Encodes this object usingJSONStringerprovided- Parameters:
stringer- -JSONStringerto be used for serialization- Throws:
JSONException- On internal errors. Shouldn't happen.
-
numberToString
public static String numberToString(Number number) throws JSONException
Encodes the number as a JSON string.- Parameters:
number- a finite value. May not beNaNsorinfinities.- Returns:
- The encoded number in string form.
- Throws:
JSONException- On internal errors. Shouldn't happen.
-
quote
public static String quote(String data)
Encodesdataas 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 string.
-
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 aJSONArrayorJSONObject, no wrapping is necessary. If the object isNULL, no wrapping is necessary. If the object is an array orCollection, returns an equivalentJSONArray. If the object is aMap, returns an equivalentJSONObject. If the object is a primitive wrapper type orString, returns the object. If the object is from ajavapackage, returns the result oftoString. If the object is some other kind of object then it is assumed to be a bean and is converted to a JSONObject. If wrapping fails, returns null.- Parameters:
o- The object to wrap.- Returns:
- The wrapped (if necessary) form of the object {$code o}
-
-