public class JSONObject
extends java.lang.Object
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.
Number types will be coerced using
doubleValue. Strings that can be coerced using
Double.valueOf(String) will be.
Number types will be coerced using
intValue. Strings that can be coerced using
Double.valueOf(String) will be, and then cast to int.
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.
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:
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.
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.
| Modifier and Type | Field and Description |
|---|---|
static java.lang.ThreadLocal<java.lang.Boolean> |
cyclicDepChkEnabled |
static java.lang.ThreadLocal<java.util.Set> |
cyclicDependencySet |
static java.lang.Object |
NULL
A sentinel value used to explicitly define a name with no value.
|
| Constructor and Description |
|---|
JSONObject()
Creates a
JSONObject with no name/value mappings. |
JSONObject(JSONObject copyFrom,
java.lang.String[] names)
Creates a new
JSONObject by copying mappings for the listed names from the given
object. |
JSONObject(JSONTokener readFrom)
Creates a new
JSONObject with name/value mappings from the next object in the tokener. |
JSONObject(java.util.Map copyFrom)
Creates a new
JSONObject by copying all name/value mappings from the given map. |
JSONObject(java.lang.Object bean)
Creates a json object from a bean
|
JSONObject(java.lang.String json)
Creates a new
JSONObject with name/value mappings from the JSON string. |
| Modifier and Type | Method and Description |
|---|---|
JSONObject |
accumulate(java.lang.String name,
java.lang.Object value)
Appends
value to the array already mapped to name. |
JSONObject |
append(java.lang.String name,
java.lang.Object value)
Appends values to the array mapped to
name. |
java.lang.Object |
get(java.lang.String name)
Returns the value mapped by
name, or throws if no such mapping exists. |
boolean |
getBoolean(java.lang.String name)
Returns the value mapped by
name if it exists and is a boolean or can be coerced to a
boolean, or throws otherwise. |
double |
getDouble(java.lang.String name)
Returns the value mapped by
name if it exists and is a double or can be coerced to a
double, or throws otherwise. |
int |
getInt(java.lang.String name)
Returns the value mapped by
name if it exists and is an int or can be coerced to an
int, or throws otherwise. |
JSONArray |
getJSONArray(java.lang.String name)
Returns the value mapped by
name if it exists and is a JSONArray, or throws otherwise. |
JSONObject |
getJSONObject(java.lang.String name)
Returns the value mapped by
name if it exists and is a JSONObject, or throws otherwise. |
long |
getLong(java.lang.String name)
Returns the value mapped by
name if it exists and is a long or can be coerced to a
long, or throws otherwise. |
static java.lang.String[] |
getNames(JSONObject x) |
java.lang.String |
getString(java.lang.String name)
Returns the value mapped by
name if it exists, coercing it if necessary, or throws if
no such mapping exists. |
boolean |
has(java.lang.String name)
Returns true if this object has a mapping for
name. |
boolean |
isNull(java.lang.String name)
Returns true if this object has no mapping for
name or if it has a mapping whose value
is NULL. |
java.util.Iterator<java.lang.String> |
keys()
Returns an iterator of the
String names in this object. |
java.util.Set<java.lang.String> |
keySet()
Returns the set of
String names in this object. |
int |
length()
Returns the number of name/value mappings in this object.
|
JSONArray |
names()
Returns an array containing the string names in this object.
|
static java.lang.String |
numberToString(java.lang.Number number)
Encodes the number as a JSON string.
|
java.lang.Object |
opt(java.lang.String name)
Returns the value mapped by
name, or null if no such mapping exists. |
boolean |
optBoolean(java.lang.String name)
Returns the value mapped by
name if it exists and is a boolean or can be coerced to a
boolean, or false otherwise. |
boolean |
optBoolean(java.lang.String name,
boolean fallback)
Returns the value mapped by
name if it exists and is a boolean or can be coerced to a
boolean, or fallback otherwise. |
double |
optDouble(java.lang.String name)
Returns the value mapped by
name if it exists and is a double or can be coerced to a
double, or NaN otherwise. |
double |
optDouble(java.lang.String name,
double fallback)
Returns the value mapped by
name if it exists and is a double or can be coerced to a
double, or fallback otherwise. |
int |
optInt(java.lang.String name)
Returns the value mapped by
name if it exists and is an int or can be coerced to an
int, or 0 otherwise. |
int |
optInt(java.lang.String name,
int fallback)
Returns the value mapped by
name if it exists and is an int or can be coerced to an
int, or fallback otherwise. |
JSONArray |
optJSONArray(java.lang.String name)
Returns the value mapped by
name if it exists and is a JSONArray, or null otherwise. |
JSONObject |
optJSONObject(java.lang.String name)
Returns the value mapped by
name if it exists and is a JSONObject, or null otherwise. |
long |
optLong(java.lang.String name)
Returns the value mapped by
name if it exists and is a long or can be coerced to a
long, or 0 otherwise. |
long |
optLong(java.lang.String name,
long fallback)
Returns the value mapped by
name if it exists and is a long or can be coerced to a
long, or fallback otherwise. |
java.lang.String |
optString(java.lang.String name)
Returns the value mapped by
name if it exists, coercing it if necessary, or the empty
string if no such mapping exists. |
java.lang.String |
optString(java.lang.String name,
java.lang.String fallback)
Returns the value mapped by
name if it exists, coercing it if necessary, or
fallback if no such mapping exists. |
JSONObject |
put(java.lang.String name,
boolean value)
Maps
name to value, clobbering any existing name/value mapping with the same
name. |
JSONObject |
put(java.lang.String name,
double value)
Maps
name to value, clobbering any existing name/value mapping with the same
name. |
JSONObject |
put(java.lang.String name,
int value)
Maps
name to value, clobbering any existing name/value mapping with the same
name. |
JSONObject |
put(java.lang.String name,
long value)
Maps
name to value, clobbering any existing name/value mapping with the same
name. |
JSONObject |
put(java.lang.String name,
java.lang.Object value)
Maps
name to value, clobbering any existing name/value mapping with the same
name. |
JSONObject |
putOpt(java.lang.String name,
java.lang.Object value)
Equivalent to
put(name, value) when both parameters are non-null; does nothing
otherwise. |
static java.lang.String |
quote(java.lang.String data)
Encodes
data as a JSON string. |
java.lang.Object |
remove(java.lang.String name)
Removes the named mapping if it exists; does nothing otherwise.
|
JSONArray |
toJSONArray(JSONArray names)
Returns an array with the values corresponding to
names. |
java.lang.String |
toString()
Encodes this object as a compact JSON string, such as:
|
java.lang.String |
toString(int indentSpaces)
Encodes this object as a human readable JSON string for debugging, such as:
|
static java.lang.Object |
wrap(java.lang.Object o)
Wraps the given object if necessary.
|
public static java.lang.ThreadLocal<java.util.Set> cyclicDependencySet
public static java.lang.ThreadLocal<java.lang.Boolean> cyclicDepChkEnabled
public static final java.lang.Object NULL
null, names
with this value:
names() array
keys() iterator
true for has(String)
get(String)
This value violates the general contract of Object.equals(java.lang.Object) by returning true when
compared to null. Its toString() method returns "null".
public JSONObject()
JSONObject with no name/value mappings.public JSONObject(java.util.Map copyFrom)
JSONObject by copying all name/value mappings from the given map.copyFrom - a map whose keys are of type String and whose values are of supported
types.java.lang.NullPointerException - if any of the map's keys are null.public JSONObject(JSONTokener readFrom) throws JSONException
JSONObject with name/value mappings from the next object in the tokener.readFrom - a tokener whose nextValue() method will yield a JSONObject.JSONException - if the parse fails or doesn't yield a JSONObject.public JSONObject(java.lang.String json)
throws JSONException
JSONObject with name/value mappings from the JSON string.json - a JSON-encoded string containing an object.JSONException - if the parse fails or doesn't yield a JSONObject.public JSONObject(JSONObject copyFrom, java.lang.String[] names) throws JSONException
JSONObject by copying mappings for the listed names from the given
object. Names that aren't present in copyFrom will be skipped.copyFrom - The source object.names - The names of the fields to copy.JSONException - On internal errors. Shouldn't happen.public JSONObject(java.lang.Object bean)
throws JSONException
bean - the bean to create the json object fromJSONException - If there is an exception while reading the beanpublic static java.lang.String[] getNames(JSONObject x)
public int length()
public JSONObject put(java.lang.String name, boolean value) throws JSONException
name to value, clobbering any existing name/value mapping with the same
name.name - The name of the value to insert.value - The value to insert.JSONException - Should not be possible.public JSONObject put(java.lang.String name, double value) throws JSONException
name to value, clobbering any existing name/value mapping with the same
name.name - The name for the new value.value - a finite value. May not be NaNs or
infinities.JSONException - if value is NaN or infinite.public JSONObject put(java.lang.String name, int value) throws JSONException
name to value, clobbering any existing name/value mapping with the same
name.name - The name for the new value.value - The new value.JSONException - Should not be possible.public JSONObject put(java.lang.String name, long value) throws JSONException
name to value, clobbering any existing name/value mapping with the same
name.name - The name of the new value.value - The new value to insert.JSONException - Should not be possible.public JSONObject put(java.lang.String name, java.lang.Object value) throws JSONException
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.name - The name of the new value.value - a JSONObject, JSONArray, String, Boolean, Integer, Long, Double,
NULL, or null. May not be NaNs or
infinities.JSONException - if the value is an invalid double (infinite or NaN).public JSONObject putOpt(java.lang.String name, java.lang.Object value) throws JSONException
put(name, value) when both parameters are non-null; does nothing
otherwise.name - The name of the value to insert.value - The value to insert.JSONException - if the value is an invalid double (infinite or NaN).public JSONObject accumulate(java.lang.String name, java.lang.Object value) throws JSONException
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.
Note that append(String, Object) provides better semantics. In particular, the mapping
for name will always be a JSONArray. Using accumulate will
result in either a JSONArray or a mapping whose type is the type of value
depending on the number of calls to it.name - The name of the field to change.value - a JSONObject, JSONArray, String, Boolean, Integer, Long, Double,
NULL or null. May not be NaNs or
infinities.JSONException - If the object being added is an invalid number.public JSONObject append(java.lang.String name, java.lang.Object value) throws JSONException
name. A new JSONArray mapping for
name will be inserted if no mapping exists. If the existing mapping for name is
not a JSONArray, a JSONException will be thrown.name - The name of the array to which the value should be appended.value - The value to append.JSONException - if name is null or if the mapping for name is
non-null and is not a JSONArray.public java.lang.Object remove(java.lang.String name)
name - The name of the mapping to remove.name, or null if there was no such mapping.public boolean isNull(java.lang.String name)
name or if it has a mapping whose value
is NULL.name - The name of the value to check on.public boolean has(java.lang.String name)
name. The mapping may be NULL.name - The name of the value to check on.namepublic java.lang.Object get(java.lang.String name)
throws JSONException
name, or throws if no such mapping exists.name - The name of the value to get.JSONException - if no such mapping exists.public java.lang.Object opt(java.lang.String name)
name, or null if no such mapping exists.name - The name of the value to get.public boolean getBoolean(java.lang.String name)
throws JSONException
name if it exists and is a boolean or can be coerced to a
boolean, or throws otherwise.name - The name of the field we want.JSONException - if the mapping doesn't exist or cannot be coerced to a boolean.public boolean optBoolean(java.lang.String name)
name if it exists and is a boolean or can be coerced to a
boolean, or false otherwise.name - The name of the field we want.public boolean optBoolean(java.lang.String name,
boolean fallback)
name if it exists and is a boolean or can be coerced to a
boolean, or fallback otherwise.name - The name of the field we want.fallback - The value to return if the field isn't there.public double getDouble(java.lang.String name)
throws JSONException
name if it exists and is a double or can be coerced to a
double, or throws otherwise.name - The name of the field we want.JSONException - if the mapping doesn't exist or cannot be coerced to a double.public double optDouble(java.lang.String name)
name if it exists and is a double or can be coerced to a
double, or NaN otherwise.name - The name of the field we want.public double optDouble(java.lang.String name,
double fallback)
name if it exists and is a double or can be coerced to a
double, or fallback otherwise.name - The name of the field we want.fallback - The value to return if the field isn't there.public int getInt(java.lang.String name)
throws JSONException
name if it exists and is an int or can be coerced to an
int, or throws otherwise.name - The name of the field we want.JSONException - if the mapping doesn't exist or cannot be coerced to an int.public int optInt(java.lang.String name)
name if it exists and is an int or can be coerced to an
int, or 0 otherwise.name - The name of the field we want.public int optInt(java.lang.String name,
int fallback)
name if it exists and is an int or can be coerced to an
int, or fallback otherwise.name - The name of the field we want.fallback - The value to return if the field isn't there.public long getLong(java.lang.String name)
throws JSONException
name if 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.name - The name of the field that we want.JSONException - if the mapping doesn't exist or cannot be coerced to a long.public long optLong(java.lang.String name)
name if 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.name - The name of the field we want.public long optLong(java.lang.String name,
long fallback)
name if it exists and is a long or can be coerced to a
long, or fallback otherwise. Note that JSON represents numbers as doubles, so this is
lossy; use strings to transfer numbers via JSON.name - The name of the field we want.fallback - The value to return if the field isn't there.public java.lang.String getString(java.lang.String name)
throws JSONException
name if it exists, coercing it if necessary, or throws if
no such mapping exists.name - The name of the field we want.JSONException - if no such mapping exists.public java.lang.String optString(java.lang.String name)
name if it exists, coercing it if necessary, or the empty
string if no such mapping exists.name - The name of the field we want.public java.lang.String optString(java.lang.String name,
java.lang.String fallback)
name if it exists, coercing it if necessary, or
fallback if no such mapping exists.name - The name of the field that we want.fallback - The value to return if the field doesn't exist.public JSONArray getJSONArray(java.lang.String name) throws JSONException
name if it exists and is a JSONArray, or throws otherwise.name - The field we want to get.JSONException - if the mapping doesn't exist or is not a JSONArray.public JSONArray optJSONArray(java.lang.String name)
name if it exists and is a JSONArray, or null otherwise.name - The name of the field we want.public JSONObject getJSONObject(java.lang.String name) throws JSONException
name if it exists and is a JSONObject, or throws otherwise.name - The name of the field that we want.JSONException - if the mapping doesn't exist or is not a JSONObject.public JSONObject optJSONObject(java.lang.String name)
name if it exists and is a JSONObject, or null otherwise.name - The name of the value we want.public JSONArray toJSONArray(JSONArray names) throws JSONException
names. The array contains null for
names that aren't mapped. This method returns null if names is either null or empty.names - The names of the fields that we want the values for.JSONException - On internal errors. Shouldn't happen.public java.util.Iterator<java.lang.String> keys()
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.public java.util.Set<java.lang.String> keySet()
String names 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.
See keys().public JSONArray names()
public java.lang.String toString()
{"query":"Pizza","locations":[94043,90210]}
toString in class java.lang.Objectpublic java.lang.String toString(int indentSpaces)
throws JSONException
{
"query": "Pizza",
"locations": [
94043,
90210
]
}
indentSpaces - the number of spaces to indent for each level of nesting.JSONException - On internal errors. Shouldn't happen.public static java.lang.String numberToString(java.lang.Number number)
throws JSONException
number - a finite value. May not be NaNs or
infinities.JSONException - On internal errors. Shouldn't happen.public static java.lang.String quote(java.lang.String data)
data as a JSON string. This applies quotes and any necessary character
escaping.data - the string to encode. Null will be interpreted as an empty string.public static java.lang.Object wrap(java.lang.Object o)
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. If the object is from
a java package, returns the result of toString. 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.
o - The object to wrap.