一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|

服務(wù)器之家 - 編程語言 - JAVA教程 - springMVC利用FastJson接口返回json數(shù)據(jù)相關(guān)配置詳解

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

2020-11-05 15:50zx JAVA教程

本篇文章主要介紹了springMVC利用FastJson接口返回json數(shù)據(jù)相關(guān)配置詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

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

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
```
 <!-- 啟用默認(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è)置(強烈建議使用Maven

?
1
2
3
4
5
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>fastjson</artifactId>
  <version>1.2.7</version>
</dependency>

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

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

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

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

Fastjson的SerializerFeature序列化屬性:

  1. QuoteFieldNames———-輸出key時是否使用雙引號,默認(rèn)為true
  2. WriteMapNullValue——–是否輸出值為null的字段,默認(rèn)為false
  3. WriteNullNumberAsZero—-數(shù)值字段如果為null,輸出為0,而非null
  4. WriteNullListAsEmpty—–List字段如果為null,輸出為[],而非null
  5. WriteNullStringAsEmpty—字符類型字段如果為null,輸出為”“,而非null
  6. 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> -->
  <!-- 數(shù)值字段如果為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的日期轉(zhuǎn)換器 -->
  <value>WriteDateUseDateFormat</value>
</list>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/zhenghuasheng/article/details/51223106

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 男人在线影院 | 国产成人精品免费大全 | 国产区1 | 免费看片黄 | 91亚洲在线 | 香蕉久久ac一区二区三区 | 日出水了特别黄的视频 | 国产精品色图 | 草莓视频在线免费观看 | 日本孕妇大胆孕交 | 国产精品成人亚洲 | 青青青青青国产免费手机看视频 | 五月天综合久久 | 国内精品久久久久久不卡影院 | 久久视频这只精品99re6 | 免费国产影视观看网站入口 | 国产亚洲福利一区二区免费看 | 精品四虎国产在免费观看 | 免费高清视频免费观看 | 含羞草传媒每天免费一次破解 | 国产高清在线播放免费观看 | 亚洲人成影院午夜网站 | 日韩在线1 | 国产精品福利短视在线播放频 | 91国语精品自产拍在线观看一 | 成人性用品 | 洗濯屋し在线观看 | 日本九九热 | 免费看又黄又爽又猛的视频软件- | 91最新入口| 日韩视频免费观看 | 狠狠香蕉 | 成人午夜爽爽爽免费视频 | 99精品国产高清自在线看超 | 美国大片成人性网 | 国产a在线| 免费精品国产 | 色啪啪888.com| www.国产自拍| 免费一级欧美片片线观看 | 午夜欧美精品久久久久久久久 |