public class JSONObject extends JSONGetter<String> implements JSON, Map<String,Object>
json = new JSONObject().put("JSON", "Hello, World!").toString();
| 限定符和类型 | 字段和说明 |
|---|---|
static int |
DEFAULT_CAPACITY
默认初始大小
|
| 构造器和说明 |
|---|
JSONObject()
构造,初始容量为
DEFAULT_CAPACITY,KEY无序 |
JSONObject(boolean isOrder)
构造,初始容量为
DEFAULT_CAPACITY |
JSONObject(CharSequence source,
boolean isOrder)
从JSON字符串解析为JSON对象,对于排序单独配置参数
|
JSONObject(int capacity,
boolean isOrder)
构造
|
JSONObject(int capacity,
boolean isIgnoreCase,
boolean isOrder)
构造
|
JSONObject(int capacity,
JSONConfig config)
构造
|
JSONObject(JSONConfig config)
构造
|
JSONObject(Object source)
构建JSONObject,JavaBean默认忽略null值,其它对象不忽略,规则如下:
value为Map,将键值对加入JSON对象
value为JSON字符串(CharSequence),使用JSONTokener解析
value为JSONTokener,直接解析
value为普通JavaBean,如果为普通的JavaBean,调用其getters方法(getXXX或者isXXX)获得值,加入到JSON对象。
|
JSONObject(Object source,
boolean ignoreNullValue)
构建JSONObject,规则如下:
value为Map,将键值对加入JSON对象
value为JSON字符串(CharSequence),使用JSONTokener解析
value为JSONTokener,直接解析
value为普通JavaBean,如果为普通的JavaBean,调用其getters方法(getXXX或者isXXX)获得值,加入到JSON对象。
|
JSONObject(Object source,
boolean ignoreNullValue,
boolean isOrder)
构建JSONObject,规则如下:
value为Map,将键值对加入JSON对象
value为JSON字符串(CharSequence),使用JSONTokener解析
value为JSONTokener,直接解析
value为普通JavaBean,如果为普通的JavaBean,调用其getters方法(getXXX或者isXXX)获得值,加入到JSON对象。
|
JSONObject(Object source,
JSONConfig config)
构建JSONObject,规则如下:
value为Map,将键值对加入JSON对象
value为JSON字符串(CharSequence),使用JSONTokener解析
value为JSONTokener,直接解析
value为普通JavaBean,如果为普通的JavaBean,调用其getters方法(getXXX或者isXXX)获得值,加入到JSON对象。
|
JSONObject(Object obj,
String... names)
构建指定name列表对应的键值对为新的JSONObject,情况如下:
1.
|
| 限定符和类型 | 方法和说明 |
|---|---|
JSONObject |
accumulate(String key,
Object value)
积累值。
|
JSONObject |
append(String key,
Object value)
追加值,如果key无对应值,就添加一个JSONArray,其元素只有value,如果值已经是一个JSONArray,则添加到值JSONArray中。
|
void |
clear() |
boolean |
containsKey(Object key) |
boolean |
containsValue(Object value) |
Set<Map.Entry<String,Object>> |
entrySet() |
boolean |
equals(Object obj) |
Object |
get(Object key) |
Object |
getByPath(String expression)
通过表达式获取JSON中嵌套的对象
.表达式,可以获取Bean对象中的属性(字段)值或者Map中key对应的值 []表达式,可以获取集合等对象中对应index的值 表达式栗子: persion persion.name persons[3] person.friends[5].name |
<T> T |
getByPath(String expression,
Class<T> resultType)
通过表达式获取JSON中嵌套的对象
.表达式,可以获取Bean对象中的属性(字段)值或者Map中key对应的值 []表达式,可以获取集合等对象中对应index的值 表达式栗子: persion persion.name persons[3] person.friends[5].name 获取表达式对应值后转换为对应类型的值 |
JSONConfig |
getConfig()
获取JSON配置
|
Object |
getObj(String key,
Object defaultValue) |
int |
hashCode() |
JSONObject |
increment(String key)
对值加一,如果值不存在,赋值1,如果为数字类型,做加一操作
|
boolean |
isEmpty() |
Set<String> |
keySet() |
JSONObject |
put(String key,
Object value)
PUT 键值对到JSONObject中,如果值为
null,将此键移除 |
void |
putAll(Map<? extends String,?> m) |
void |
putByPath(String expression,
Object value)
设置表达式指定位置(或filed对应)的值
若表达式指向一个JSONArray则设置其坐标对应位置的值,若指向JSONObject则put对应key的值 注意:如果为JSONArray,设置值下标小于其长度,将替换原有值,否则追加新值 .表达式,可以获取Bean对象中的属性(字段)值或者Map中key对应的值 []表达式,可以获取集合等对象中对应index的值 表达式栗子: persion persion.name persons[3] person.friends[5].name |
JSONObject |
putOnce(String key,
Object value)
一次性Put 键值对,如果key已经存在抛出异常,如果键值中有null值,忽略
|
JSONObject |
putOpt(String key,
Object value)
在键和值都为非空的情况下put到JSONObject中
|
Object |
remove(Object key) |
JSONObject |
setDateFormat(String format)
设置转为字符串时的日期格式,默认为时间戳(null值)
|
int |
size() |
<T> T |
toBean(Class<T> clazz)
转为实体类对象,转换异常将被抛出
|
<T> T |
toBean(Type type)
转为实体类对象
|
<T> T |
toBean(Type type,
boolean ignoreError)
转为实体类对象
|
<T> T |
toBean(TypeReference<T> reference)
转为实体类对象,转换异常将被抛出
|
JSONArray |
toJSONArray(Collection<String> names)
将指定KEY列表的值组成新的JSONArray
|
String |
toJSONString(int indentFactor)
格式化输出JSON字符串
|
String |
toString()
返回JSON字符串
如果解析错误,返回 null |
String |
toStringPretty()
格式化打印JSON,缩进为4个空格
|
Collection<Object> |
values() |
Writer |
write(Writer writer)
将JSON内容写入Writer,无缩进
Warning: This method assumes that the data structure is acyclical. |
Writer |
write(Writer writer,
int indentFactor,
int indent)
将JSON内容写入Writer
Warning: This method assumes that the data structure is acyclical. |
get, get, getBean, getJSONArray, getJSONObject, getStrEscaped, getStrEscaped, isNullgetBigDecimal, getBigInteger, getBool, getByte, getChar, getDate, getDouble, getEnum, getFloat, getInt, getLong, getShort, getStrgetBigDecimal, getBigInteger, getBool, getByte, getChar, getDate, getDouble, getEnum, getFloat, getInt, getLong, getObj, getShort, getStrpublic static final int DEFAULT_CAPACITY
public JSONObject()
DEFAULT_CAPACITY,KEY无序public JSONObject(boolean isOrder)
DEFAULT_CAPACITYisOrder - 是否有序public JSONObject(int capacity,
boolean isOrder)
capacity - 初始大小isOrder - 是否有序public JSONObject(int capacity,
boolean isIgnoreCase,
boolean isOrder)
capacity - 初始大小isIgnoreCase - 是否忽略KEY大小写isOrder - 是否有序public JSONObject(JSONConfig config)
config - JSON配置项public JSONObject(int capacity,
JSONConfig config)
capacity - 初始大小config - JSON配置项public JSONObject(Object source)
source - JavaBean或者Map对象或者Stringpublic JSONObject(Object source, boolean ignoreNullValue)
source - JavaBean或者Map对象或者StringignoreNullValue - 是否忽略空值public JSONObject(Object source, boolean ignoreNullValue, boolean isOrder)
source - JavaBean或者Map对象或者StringignoreNullValue - 是否忽略空值,如果source为JSON字符串,不忽略空值isOrder - 是否有序public JSONObject(Object source, JSONConfig config)
source - JavaBean或者Map对象或者Stringconfig - JSON配置文件public JSONObject(Object obj, String... names)
1. 若obj为Map,则获取name列表对应键值对 2. 若obj为普通Bean,使用反射方式获取字段名和字段值KEY或VALUE任意一个为null则不加入,字段不存在也不加入
obj - 包含需要字段的Bean对象或者Map对象names - 需要构建JSONObject的字段名列表public JSONObject(CharSequence source, boolean isOrder) throws JSONException
source - 以大括号 {} 包围的字符串,其中KEY和VALUE使用 : 分隔,每个键值对使用逗号分隔isOrder - 是否有序JSONException - JSON字符串语法错误public JSONConfig getConfig()
JSONConfigpublic JSONObject setDateFormat(String format)
format - 格式,null表示使用时间戳public JSONArray toJSONArray(Collection<String> names) throws JSONException
names - KEY列表JSONException - If any of the values are non-finite numbers.public <T> T toBean(Class<T> clazz)
T - Bean类型clazz - 实体类public <T> T toBean(TypeReference<T> reference)
T - Bean类型reference - TypeReference类型参考子类,可以获取其泛型参数中的Type类型public <T> T toBean(Type type, boolean ignoreError)
T - Bean类型type - TypeignoreError - 是否忽略转换错误public boolean containsKey(Object key)
containsKey 在接口中 Map<String,Object>public boolean containsValue(Object value)
containsValue 在接口中 Map<String,Object>public Object getObj(String key, Object defaultValue)
getObj 在接口中 OptBasicTypeGetter<String>getObj 在类中 OptNullBasicTypeFromObjectGetter<String>public Object getByPath(String expression)
JSONpersion persion.name persons[3] person.friends[5].name
getByPath 在接口中 JSONexpression - 表达式BeanPath.get(Object)public <T> T getByPath(String expression, Class<T> resultType)
JSONpersion persion.name persons[3] person.friends[5].name获取表达式对应值后转换为对应类型的值
getByPath 在接口中 JSONT - 返回值类型expression - 表达式resultType - 返回值类型BeanPath.get(Object)public void putByPath(String expression, Object value)
JSONpersion persion.name persons[3] person.friends[5].name
public JSONObject put(String key, Object value) throws JSONException
null,将此键移除put 在接口中 Map<String,Object>key - 键value - 值对象. 可以是以下类型: Boolean, Double, Integer, JSONArray, JSONObject, Long, String, or the JSONNull.NULL.JSONException - 值是无穷数字抛出此异常public JSONObject putOnce(String key, Object value) throws JSONException
key - 键value - 值对象,可以是以下类型: Boolean, Double, Integer, JSONArray, JSONObject, Long, String, or the JSONNull.NULL.JSONException - 值是无穷数字、键重复抛出异常public JSONObject putOpt(String key, Object value) throws JSONException
key - 键value - 值对象,可以是以下类型: Boolean, Double, Integer, JSONArray, JSONObject, Long, String, or the JSONNull.NULL.JSONException - 值是无穷数字public JSONObject accumulate(String key, Object value) throws JSONException
key - 键value - 被积累的值JSONException - 如果给定键为null或者键对应的值存在且为非JSONArraypublic JSONObject append(String key, Object value) throws JSONException
key - 键value - 值JSONException - 如果给定键为null或者键对应的值存在且为非JSONArraypublic JSONObject increment(String key) throws JSONException
key - A key string.JSONException - 如果存在值非Integer, Long, Double, 或 Float.public String toStringPretty() throws JSONException
toStringPretty 在接口中 JSONJSONException - 包含非法数抛出此异常public String toJSONString(int indentFactor) throws JSONException
toJSONString 在接口中 JSONindentFactor - 每层缩进空格数JSONException - 包含非法数抛出此异常public Writer write(Writer writer) throws JSONException
JSONwrite 在接口中 JSONwriter - WriterJSONException - JSON相关异常public Writer write(Writer writer, int indentFactor, int indent) throws JSONException
JSONwrite 在接口中 JSONwriter - writerindentFactor - 缩进因子,定义每一级别增加的缩进量indent - 本级别缩进量JSONException - JSON相关异常Copyright © 2019. All rights reserved.