java处理json数据 如何使用json-lib包

阅读更多
使用 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输出

  


代码

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 );
 

输出

1  
   2  
   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]; }]  



他方式处理参考

你可能感兴趣的:(json,Java,Bean,XML,正则表达式)