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输出
代码
JSONObject json = JSONObject.fromObject("{\"name\":\"json\",\"bool\":true,\"int\":1}"); String xml = XMLSerializer.write( json );
xml输出
json true 1
代码
JSONArray json = JSONArray.fromObject("[1,2,3]"); String xml = XMLSerializer.write( json );
输出
12 3
从xml转到json
XMLSerializer 把每个元素都看为一个stirng,除非类型参数已指定。
JSONFunction 需要附加的一个参数来指定function的参数。
所有的xml属性都有一个“@”前缀,text节点都有属性名为“#text”
xml输入
return matrix[i][j];
代码
JSONArray json = (JSONArray) XMLSerializer.read( xml ); System.out.println( json ); // prints [function(i,j){ return matrix[i][j]; }]
其 他方式处理参考