溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

springMVC利用FastJson接口返回json數(shù)據(jù)相關(guān)配置詳解

發(fā)布時(shí)間:2020-10-13 19:19:18 來(lái)源:腳本之家 閱讀:190 作者:zx 欄目:編程語(yǔ)言

一直使用的是FastJson,感覺(jué)還不錯(cuò),很方便。看了一段別人的分析,覺(jué)得很有道理。

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

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

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

springMVC使用fastJson很簡(jiǎn)單,在springMVC的配置文件中作如下配置:

```
 <!-- 啟用默認(rèn)配置 -->
  <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,版本可以切換至最新版本,可使用如下設(shè)置(強(qiáng)烈建議使用Maven

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

當(dāng)屬性值為空的時(shí)候,fastjson默認(rèn)是不輸出的,

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);
//輸出結(jié)果:{"a":1,"b":"",d:"zhenghuasheng"}

從輸出結(jié)果可以看出,null對(duì)應(yīng)的key已經(jīng)被過(guò)濾掉;這明顯不是我們想要的結(jié)果,這時(shí)我們就需要用到fastjson的SerializerFeature序列化屬性

也就是這個(gè)方法:JSONObject.toJSONString(Object object, SerializerFeature... features)

Fastjson的SerializerFeature序列化屬性:

  1. QuoteFieldNames———-輸出key時(shí)是否使用雙引號(hào),默認(rèn)為true
  2. WriteMapNullValue——–是否輸出值為null的字段,默認(rèn)為false
  3. WriteNullNumberAsZero—-數(shù)值字段如果為null,輸出為0,而非null
  4. WriteNullListAsEmpty—–List字段如果為null,輸出為[],而非null
  5. WriteNullStringAsEmpty—字符類(lèi)型字段如果為null,輸出為”“,而非null
  6. WriteNullBooleanAsFalse–Boolean字段如果為null,輸出為false,而非null
      <!-- 輸出key時(shí)是否使用雙引號(hào) -->
      <value>QuoteFieldNames</value>
      <!-- 是否輸出值為null的字段 -->
      <!-- <value>WriteMapNullValue</value> -->
      <!-- 數(shù)值字段如果為null,輸出為0,而非null -->
      <value>WriteNullNumberAsZero</value>
      <!-- List字段如果為null,輸出為[],而非null -->
      <value>WriteNullListAsEmpty</value>
      <!-- 字符類(lèi)型字段如果為null,輸出為"",而非null -->
      <value>WriteNullStringAsEmpty</value>
      <!-- Boolean字段如果為null,輸出為false,而非null -->
      <value>WriteNullBooleanAsFalse</value>
      <!-- null String不輸出 -->
      <value>WriteNullStringAsEmpty</value>
      <!-- null String也要輸出 -->
      <!-- <value>WriteMapNullValue</value> -->

      <!-- Date的日期轉(zhuǎn)換器 -->
      <value>WriteDateUseDateFormat</value>
    </list>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI