springMVC利用FastJson接口返回json數據相關配置詳解

一直使用的是FastJson,感覺還不錯,很方便??戳艘欢蝿e人的分析,覺得很有道理。

創(chuàng)新互聯于2013年成立,先為二道等服務建站,二道等地企業(yè),進行企業(yè)商務咨詢服務。為二道企業(yè)網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。

為什么要使用Fastjson,其實原因不需要太多,喜歡就行。

我之所以要替換掉Jackson最主要的原因是Jackson在處理對象之前的循環(huán)嵌套關系時不便。

ps:什么是對象間的循環(huán)嵌套?比如A有一個List,B對象里又有一個A對象,當然返回A對象的Json字符串時,如果是
Jackson就會發(fā)生異常,因為Jackson天生不具備處理這種關系的能力,而Fastjson正好具備了這種能力(另,如果你用的是
Jackson,可以使用相應的注解來支持對象間的循環(huán)嵌套,具體是什么注解忘了,你可以Google一下Jackson循環(huán)嵌套就有很多答案)。]

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序列化屬性:

  1. QuoteFieldNames———-輸出key時是否使用雙引號,默認為true
  2. WriteMapNullValue——–是否輸出值為null的字段,默認為false
  3. WriteNullNumberAsZero—-數值字段如果為null,輸出為0,而非null
  4. WriteNullListAsEmpty—–List字段如果為null,輸出為[],而非null
  5. WriteNullStringAsEmpty—字符類型字段如果為null,輸出為”“,而非null
  6. 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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯。

當前標題:springMVC利用FastJson接口返回json數據相關配置詳解
當前網址:http://muchs.cn/article40/jojoeo.html

成都網站建設公司_創(chuàng)新互聯,為您提供響應式網站、ChatGPT、網站內鏈、用戶體驗、品牌網站設計、網站策劃

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

外貿網站制作