一直使用的是FastJson,感觉还不错,很方便。看了一段别人的分析,觉得很有道理。
为什么要使用Fastjson,其实原因不需要太多,喜欢就行。
我之所以要替换掉Jackson最主要的原因是Jackson在处理对象之前的循环嵌套关系时不便。
ps:什么是对象间的循环嵌套?比如A有一个List,B对象里又有一个A对象,当然返回A对象的Json字符串时,如果是
Jackson就会发生异常,因为Jackson天生不具备处理这种关系的能力,而Fastjson正好具备了这种能力(另,如果你用的是
Jackson,可以使用相应的注解来支持对象间的循环嵌套,具体是什么注解忘了,你可以Google一下Jackson循环嵌套就有很多答案)。]
springMVC使用fastJson很简单,在springMVC的配置文件中作如下配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
```
<!-- 启用默认配置 -->
< mvc:annotation-driven >
< mvc:message-converters register-defaults = "true" >
<!-- 配置Fastjson支持 -->
< bean class = "com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter" >
< property name = "supportedMediaTypes" >
< list >
< value >text/html;charset=UTF-8</ value >
< value >application/json</ value >
</ list >
</ property >
< property name = "features" >
< list >
< value >WriteMapNullValue</ value >
< value >QuoteFieldNames</ value >
</ list >
</ property >
</ bean >
</ mvc:message-converters >
</ mvc:annotation-driven >
|
别忘了添加Fastjson的包,如果使用Maven,版本可以切换至最新版本,可使用如下设置(强烈建议使用Maven
1
2
3
4
5
|
< dependency >
< groupId >com.alibaba</ groupId >
< artifactId >fastjson</ artifactId >
< version >1.2.7</ version >
</ dependency >
|
当属性值为空的时候,fastjson默认是不输出的,
1
2
3
4
5
6
7
8
9
|
Map < String , Object > jsonMap = new HashMap< String , Object>();
jsonMap.put( "a" , 1 );
jsonMap.put( "b" , "" );
jsonMap.put( "c" , null );
jsonMap.put( "d" , "zhenghuasheng" );
String str = JSONObject.toJSONString(jsonMap);
System.out.println(str);
//输出结果:{"a":1,"b":"",d:"zhenghuasheng"}
|
从输出结果可以看出,null对应的key已经被过滤掉;这明显不是我们想要的结果,这时我们就需要用到fastjson的SerializerFeature序列化属性
也就是这个方法:JSONObject.toJSONString(Object object, SerializerFeature... features)
Fastjson的SerializerFeature序列化属性:
- QuoteFieldNames———-输出key时是否使用双引号,默认为true
- WriteMapNullValue——–是否输出值为null的字段,默认为false
- WriteNullNumberAsZero—-数值字段如果为null,输出为0,而非null
- WriteNullListAsEmpty—–List字段如果为null,输出为[],而非null
- WriteNullStringAsEmpty—字符类型字段如果为null,输出为”“,而非null
- WriteNullBooleanAsFalse–Boolean字段如果为null,输出为false,而非null
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<!-- 输出key时是否使用双引号 -->
< value >QuoteFieldNames</ value >
<!-- 是否输出值为null的字段 -->
<!-- <value>WriteMapNullValue</value> -->
<!-- 数值字段如果为null,输出为0,而非null -->
< value >WriteNullNumberAsZero</ value >
<!-- List字段如果为null,输出为[],而非null -->
< value >WriteNullListAsEmpty</ value >
<!-- 字符类型字段如果为null,输出为"",而非null -->
< value >WriteNullStringAsEmpty</ value >
<!-- Boolean字段如果为null,输出为false,而非null -->
< value >WriteNullBooleanAsFalse</ value >
<!-- null String不输出 -->
< value >WriteNullStringAsEmpty</ value >
<!-- null String也要输出 -->
<!-- <value>WriteMapNullValue</value> -->
<!-- Date的日期转换器 -->
< value >WriteDateUseDateFormat</ value >
</ list >
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/zhenghuasheng/article/details/51223106