使用 JSONSerializer
JSONSerializer利用JSONObject和JSONArray的构造器可以把任何java对象转换为json格式;转换java对象到json格式使用JSONSerializer.toJSON();转换正确的json值到java对象使用toJava()方法,前提是这个对象实现JSONSerializer接口;上个方法是一个实例方法因为序列器需要特殊的配置才能把json对象转换到bean类,array,List或者DynaBean
使用arrays 和 collections
把一个java array或者collection转换为JSONArray最简单的方法就是使用静态工厂方法JSONArray. JSONArray.fromObject(),这个会检查参数并调用正确的工厂或这构造器。
例子:
boolean[] boolArray = new boolean[]{true,false,true};
JSONArray jsonArray = JSONArray.fromObject( boolArray );
System.out.println( jsonArray );
// prints [true,false,true]
List list = new ArrayList();
list.add( "first" );
list.add( "second" );
JSONArray jsonArray = JSONArray.fromObject( list );
System.out.println( jsonArray );
// prints ["first","second"]
JSONArray jsonArray = JSONArray.fromObject( "['json','is','easy']" );
System.out.println( jsonArray );
// prints ["json","is","easy"]
Beans & Maps转到JSON
把一个java bean或者map转换为JSONObject最简单的方法就是使用静态工厂方法JSONObject. JSONObject.fromObject(),这个会检查参数并调用正确的工厂或这构造器。
例子:
Map map = new HashMap();
map.put( "name", "json" );
map.put( "bool", Boolean.TRUE );
map.put( "int", new Integer(1) );
map.put( "arr", new String[]{"a","b"} );
map.put( "func", "function(i){ return this.arr[i]; }" );
JSONObject jsonObject = JSONObject.fromObject( map );
System.out.println( jsonObject );
// prints ["name":"json","bool":true,"int":1,"arr":["a","b"],"func":function(i){ return this.arr[i]; }]
class MyBean{
private String name = "json";
private int pojoId = 1;
private char[] options = new char[]{'a','f'};
private String func1 = "function(i){ return this.options[i]; }";
private JSONFunction func2 = new JSONFunction(new String[]{"i"},"return this.options[i];");
// getters & setters
...
}
JSONObject jsonObject = JSONObject.fromObject( new MyBean() );
System.out.println( jsonObject );
/* prints
{"name":"json","pojoId":1,"options":["a","f"],
"func1":function(i){ return this.options[i];},
"func2":function(i){ return this.options[i];}}
*/
把 JSON 转为 Beans
Json-lib可以把一个JSONObject转换为DynaBean 或 制定bean类。
转到 DynaBean:
String json = "{name=\"json\",bool:true,int:1,double:2.2,func:function(a){ return a; },array:[1,2]}";
JSONObject jsonObject = JSONObject.fromObject( json );
Object bean = JSONObject.toBean( jsonObject );
assertEquals( jsonObject.get( "name" ), PropertyUtils.getProperty( bean, "name" ) );
assertEquals( jsonObject.get( "bool" ), PropertyUtils.getProperty( bean, "bool" ) );
assertEquals( jsonObject.get( "int" ), PropertyUtils.getProperty( bean, "int" ) );
assertEquals( jsonObject.get( "double" ), PropertyUtils.getProperty( bean, "double" ) );
assertEquals( jsonObject.get( "func" ), PropertyUtils.getProperty( bean, "func" ) );
List expected = JSONArray.toList( jsonObject.getJSONArray( "array" ) );
Assertions.assertListEquals( expected, (List) PropertyUtils.getProperty( bean, "array" ) );
转到bean:
String json = "{bool:true,integer:1,string:\"json\"}";
JSONObject jsonObject = JSONObject.fromObject( json );
BeanA bean = (BeanA) JSONObject.toBean( jsonObject, BeanA.class );
assertEquals( jsonObject.get( "bool" ), Boolean.valueOf( bean.isBool() ) );
assertEquals( jsonObject.get( "integer" ), new Integer( bean.getInteger() ) );
assertEquals( jsonObject.get( "string" ), bean.getString() );
转到指定bean时有两种特殊的情况:
如果目标bean包含有map属性且必须包含其他beans,
JSONObject.toBean()将把嵌套beans转成DynaBeans,如果你需要把这些beans转成指定的类,可以把定义一个map属性存放要转换的指定类及JSONObject的要转换的属性。
JSONObject.toBean()可以传第三个参数,一个map,这个map将提供这些提示。key必须是JSONObject的一个属性名或者匹配对象属性的正则表达式,value必须是一个calss对象。
第二种情况是当目标bean有Collection (List)属性而且包含其他beans,这种情况就没办法提示类转换,唯一的办法就是先把collection 转换成单个DynaBean ,然后放入指定bean。
为了解决这种情况,EZMorph提供了一个Morpher来解决转换DynaBean 到制定bean的能力,
BeanMorpher。
例子:
class MyBean{
private List data;
// getters & setters
}
class Person{
private String name;
// getters & setters
}
...
String json = "{'data':[{'name':'Wallace'},{'name':'Grommit'}]}";
Map classMap = new HashMap();
classMap.put( "data", Person.class );
MyBean bean = JSONObject.toBean( JSONObject.fromObject(json), MyBean.class, classMap );
MyBean 实例在"data"内有DynaBeans属性,所以可以用迭代器进行部分后置处理。
例子:
Morpher dynaMorpher = new BeanMorpher( Person.class, JSONUtils.getMorpherRegistry() );
morpherRegistry.registerMorpher( dynaMorpher );
List output = new ArrayList();
for( Iterator i = bean.getData().iterator(); i.hasNext(); ){
output.add( morpherRegistry.morph( Person.class, i.next() ) );
}
bean.setData( output );
使用xml
从1.1版本后与xml的转换就容易多了,转换JSONObjects 和 JSONArrays 从xml或者到xml都可以通过XMLSerializer完成。
从json转到xml
把json格式写到xml直接调用XMLSerializer.write(),为了更好的控制输出必须配置很多选项;比如想更改根元素的默认名称,对象的默认名称,数组的默认名称,元素的默认名称等;如果你想输出命名空间信息但是你的json并不包含这些信息,没事你有8中方式去注册管理命名空间,这种方式指定的命名空间对其他的在json内部声明的命名空间有优先级。
默认的XMLSerializer 添加特殊属性给每个xml元素以便更好的转换回json格式,所以你可能需要去配置以跳过这些附加属性。
任何JSONObject的以'@'开头的特性都可以被看为一个属性,任何名为'#text'的特性将被看为一个Text 节点。
请查看javadoc以获取XMLSerializer 的更多配置选项。
代码
JSONObject json = new JSONObject( true );
String xml = XMLSerializer.write( json );
xml输出
<o class="object" null="true">
代码
JSONObject json = JSONObject.fromObject("{\"name\":\"json\",\"bool\":true,\"int\":1}");
String xml = XMLSerializer.write( json );
xml输出
<o class="object">
<name type="string">json</name>
<bool type="boolean">true</bool>
<int type="number">1</int>
</o>
代码
JSONArray json = JSONArray.fromObject("[1,2,3]");
String xml = XMLSerializer.write( json );
输出
<a class="array"<
<e type="number">1</e>
<e type="number">2</e>
<e type="number">3</e>
</a>
从xml转到json
XMLSerializer 把每个元素都看为一个stirng,除非类型参数已指定。
JSONFunction 需要附加的一个参数来指定function的参数。
所有的xml属性都有一个“@”前缀,text节点都有属性名为“#text”
xml输入
<a class="array">
<e type="function" params="i,j">
return matrix[i][j];
</e>
</a>
代码
JSONArray json = (JSONArray) XMLSerializer.read( xml );
System.out.println( json );
// prints [function(i,j){ return matrix[i][j]; }]
其他方式处理参考