1. 程式人生 > >springMVC利用FastJson介面返回json資料相關配置

springMVC利用FastJson介面返回json資料相關配置

一直使用的是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>