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

[b]使用 JSONSerializer[/b]
JSONSerializer利用JSONObject和JSONArray的构造器可以把任何java对象转换为json格式;转换java对象到json格式使用JSONSerializer.toJSON();转换正确的json值到java对象使用toJava()方法,前提是这个对象实现JSONSerializer接口;上个方法是一个实例方法因为序列器需要特殊的配置才能把json对象转换到bean类,array,List或者DynaBean
[b]使用arrays 和 collections[/b]
把一个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的能力, [url=http://ezmorph.sourceforge.net/apidocs/net/sf/ezmorph/bean/BeanMorpher.html]BeanMorpher[/url]。

例子:

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


[b]使用xml[/b]
从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>


[b]从xml转到json[/b]

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



[url=http://json-lib.sourceforge.net/xref-test/net/sf/json/TestJSONObject.html]其[b]他方式处理参考[/b][/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值