加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 19:49:57 所属栏目:Java 来源:网络整理
导读:一直使用的是FastJson,感觉还不错,很方便。看了一段别人的分析,觉得很有道理。 为什么要使用Fastjson,其实原因不需要太多,喜欢就行。 我之所以要替换掉Jackson最主要的原因是Jackson在处理对象之前的循环嵌套关系时不便。 ps:什么是对象间的循环嵌套?

一直使用的是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序列化属性:

  1. QuoteFieldNames―――-输出key时是否使用双引号,默认为true
  2. WriteMapNullValue――C是否输出值为null的字段,默认为false
  3. WriteNullNumberAsZero―-数值字段如果为null,输出为0,而非null
  4. WriteNullListAsEmpty―CList字段如果为null,输出为[],而非null
  5. WriteNullStringAsEmpty―字符类型字段如果为null,输出为”“,而非null
  6. WriteNullBooleanAsFalseCBoolean字段如果为null,输出为false,而非null
      <!-- 输出key时是否使用双引号 -->
      <value>QuoteFieldNames</value>
      <!-- 是否输出值为null的字段 -->
      <!-- <value>WriteMapNullValue</value> -->
      <!-- 数值字段如果为null,而非null -->
      <value>WriteNullNumberAsZero</value>
      <!-- List字段如果为null,而非null -->
      <value>WriteNullListAsEmpty</value>
      <!-- 字符类型字段如果为null,输出为"",而非null -->
      <value>WriteNullStringAsEmpty</value>
      <!-- Boolean字段如果为null,而非null -->
      <value>WriteNullBooleanAsFalse</value>
      <!-- null String不输出 -->
      <value>WriteNullStringAsEmpty</value>
      <!-- null String也要输出 -->
      <!-- <value>WriteMapNullValue</value> -->

      <!-- Date的日期转换器 -->
      <value>WriteDateUseDateFormat</value>
    </list>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

您可能感兴趣的文章:

  • springmvc fastjson 反序列化时间格式化方法(推荐)
  • 详解在springmvc中解决FastJson循环引用的问题
  • Spring MVC+FastJson+Swagger集成的完整实例教程
  • Spring MVC+FastJson+hibernate-validator整合的完整实例教程

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读