fastjson总结

** fastjson 版本: 1.2.36 **

主要 API

序列化 API (String JSON.toJSONString(Object …)) : 将对象序列化为 json 字符串
反序列化 API (T JSON.parseObject(String str, …)) 将 json 字符串序列化为对象.

JSON.toJSONString(Object …)

在这里插入图片描述
有多个重载方法,不同的参数对序列化过程进行控制。可以看到,主要是通过三个参数来对序列化进行干预的,SerializeConfig 这是序列化全局配置, SerializeFilter 序列化过滤器,SerializeFeature 这是fastjson自定义的特征枚举变量,定制序列化过程。

SerializeFeature

为什么先说这个,因为这个应用范围最广,能够覆盖大部分的序列化要求。
这是一个枚举类,列举了一系列序列化的参数。
在这里插入图片描述在这里插入图片描述

package com.alibaba.fastjson.serializer;
/**
 * 
 */
public enum SerializerFeature {
    QuoteFieldNames,  // 输出 Key 时是否使用双引号, 默认 true
    UseSingleQuotes,  // 输出key时使用单引号而不是双引号, 默认 false
    WriteMapNullValue,  // 是否输出值为 null 的字段, 默认 false, 默认不输出值为 null 的字段
    WriteEnumUsingToString, // Enum 输出其toString() 值,可以重写 toString 来自定义输出形式,但是这样做会带来一个问题,对应的反序列化使用的Enum的静态方法valueof可能无法识别自行生成的toString(),导致反序列化出错
    WriteEnumUsingName,    // Enum 输出其name() 值,默认 true, 如果需要序列化其 ordinal() 值, 禁用掉该选项,如何禁用具体代码见后文
    UseISO8601DateFormat, // Date使用ISO8601格式输出,默认为 false
    WriteNullListAsEmpty,  // List 字段如果为 null,输出 [] 而不是 null,默认 false
    WriteNullStringAsEmpty, // String 字段如果为 null, 输出 "",而不是 null,默认 false
    WriteNullNumberAsZero, // 数值字段如果为 null, 输出0而不是null,默认 false
    WriteNullBooleanAsFalse,  // Boolean字段如果为 null, 输出 false而不是 null,默认 false
    SkipTransientField, // 字段如果加了@Transient 注解,则不序列化该字段, 默认 true
    SortField,  // 按字段名称排序后输出, 默认 true, 会按字段名称字母排序。 
    /** @deprecated */
    @Deprecated
    WriteTabAsSpecial,
    PrettyFormat,   // 是否格式化输出
    WriteClassName, // 序列化时写入类型信息,默认 false。反序列化时需用到
    DisableCircularReferenceDetect, //消除对同一对象循环引用的问题,默认 false
    WriteSlashAsSpecial,  // 对斜杠 / 进行转义, 转义成 \/
    BrowserCompatible,
    WriteDateUseDateFormat,  // 全局修改日期格式,默认为false。JSON.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd";JSON.toJSONString(obj, SerializerFeature.WriteDateUseDateFormat);
    NotWriteRootClassName,
    /** @deprecated */
    DisableCheckSpecialChar, //一个对象的字符串属性
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中使用Fastjson作为JSON序列化器,首先需要添加Fastjson的依赖项,可以在pom.xml文件中添加以下依赖项: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.75</version> </dependency> ``` 然后,在Spring Boot应用程序的配置文件中,可以使用以下属性来配置Fastjson的行为: ```properties # 配置Fastjson为默认的JSON序列化器 spring.http.converters.preferred-json-mapper=fastjson # 配置Fastjson的特性 spring.fastjson.serializer.xxx=yyy ``` 其中,xxx可以为以下任意一个特性: | 属性 | 描述 | | ---- | ---- | | writeMapNullValue | 是否输出值为null的字段,默认为false | | writeNullListAsEmpty | 是否输出空的list,默认为false | | writeNullStringAsEmpty | 是否输出空的字符串,默认为false | | writeNullBooleanAsFalse | 是否输出null的布尔值,默认为false | | writeDateUseDateFormat | 是否使用日期格式化,默认为false | | notWriteRootClassName | 是否输出类名,默认为false | | sortField | 是否按照字段名称排序后输出,默认为false | | indentOutput | 是否缩进输出,默认为false | | quoteFieldNames | 是否输出key作为双引号包围的字符串,默认为true | | ignoreNonFieldGetter | 是否忽略getter方法的返回值,默认为false | | ignoreErrorGetter | 是否忽略getter方法的错误,默认为false | 其中,yyy为相应的特性值。例如: ```properties # 配置Fastjson为默认的JSON序列化器 spring.http.converters.preferred-json-mapper=fastjson # 配置Fastjson的特性 spring.fastjson.serializer.writeMapNullValue=true spring.fastjson.serializer.writeNullListAsEmpty=true spring.fastjson.serializer.writeNullStringAsEmpty=true spring.fastjson.serializer.writeNullBooleanAsFalse=true spring.fastjson.serializer.writeDateUseDateFormat=true spring.fastjson.serializer.notWriteRootClassName=true spring.fastjson.serializer.sortField=true spring.fastjson.serializer.indentOutput=true spring.fastjson.serializer.quoteFieldNames=false spring.fastjson.serializer.ignoreNonFieldGetter=true spring.fastjson.serializer.ignoreErrorGetter=true ``` 除了上述属性外,还可以使用@JSONField注解来控制序列化的行为。例如: ```java public class MyObject { @JSONField(name = "myProperty", serialize = false) private String myProperty; // getters and setters } ``` 这将使Fastjson序列化时将Java对象属性名“myProperty”映射到JSON属性名“myProperty”,并且忽略该属性的序列化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值