springMVC利用FastJson接口返回json数据相关配置

来源:互联网 发布:经典伤感网络歌曲 编辑:程序博客网 时间:2024/06/06 20:06

一直使用的是FastJson,感觉还不错,很方便。看了一段别人的分析,觉得很有道理。

[为什么要使用Fastjson,其实原因不需要太多,喜欢就行。
我之所以要替换掉Jackson最主要的原因是Jackson在处理对象之前的循环嵌套关系时不便。
ps:什么是对象间的循环嵌套?比如A有一个List,B对象里又有一个A对象,当然返回A对象的Json字符串时,如果是
Jackson就会发生异常,因为Jackson天生不具备处理这种关系的能力,而Fastjson正好具备了这种能力(另,如果你用的是
Jackson,可以使用相应的注解来支持对象间的循环嵌套,具体是什么注解忘了,你可以Google一下Jackson循环嵌套就有很多答案)。]

springMVC使用fastJson很简单,在springMVC的配置文件中作如下配置:

``` <!-- 启用默认配置 -->    <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

<dependency>    <groupId>com.alibaba</groupId>    <artifactId>fastjson</artifactId>    <version>1.2.7</version></dependency>

当属性值为空的时候,fastjson默认是不输出的,

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

           <!-- 输出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>
3 0