自定义springboot fastjson输出的问题

博客介绍了fastjson的循环引用,其会将对象解析成通过$ref标示的引用,并说明了不同引用描述。还提供了禁止循环引用的方案,同时列举了SerializerFeature中的参数类型,如QuoteFieldNames、UseSingleQuotes等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

循环引用:当一个对象包含另一个对象时,fastjson就会把该对象解析成引用。引用是通过$ref标示的,下面介绍一些引用的描述

ref":".."上一级"ref":".." 上一级 "ref":"..""ref”:"@" 当前对象,也就是自引用
ref":"ref":"ref":"” 根对象
ref":"ref":"ref":".children.0” 基于路径的引用,相当于 root.getChildren().get(0)
fastjson提供了多种json转换方案,有兴趣的同学可以自己看看源码,这里我们可以采用禁止循环引用的方案:
String s = JSON.toJSONStringWithDateFormat(0,“yyyy-MM-dd HH:mm:ss”,SerializerFeature.DisableCircularReferenceDetect);

@Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        // 初始化转换器
        FastJsonHttpMessageConverter fastConvert = new FastJsonHttpMessageConverter();
        // 初始化一个转换器配置
        FastJsonConfig fastJsonConfig = new FastJsonConfig();
        JSON.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd HH:mm";
        fastJsonConfig.setSerializerFeatures(SerializerFeature.BrowserCompatible,
                SerializerFeature.WriteNullListAsEmpty,
                SerializerFeature.PrettyFormat,
                SerializerFeature.WriteDateUseDateFormat,
                SerializerFeature.WriteNullStringAsEmpty,
                SerializerFeature.WriteMapNullValue,
                SerializerFeature.DisableCircularReferenceDetect);
        //解决Long转json精度丢失的问题
        SerializeConfig serializeConfig = SerializeConfig.globalInstance;
        serializeConfig.put(BigInteger.class, ToStringSerializer.instance);
        serializeConfig.put(Long.class, ToStringSerializer.instance);
        serializeConfig.put(Long.TYPE, ToStringSerializer.instance);
        fastJsonConfig.setSerializeConfig(serializeConfig);
        // 将配置设置给转换器并添加到HttpMessageConverter转换器列表中
        fastConvert.setFastJsonConfig(fastJsonConfig);
        converters.add(fastConvert);
    }

下面是SerializerFeature中的参数类型感兴趣的通过可以了解下!
QuoteFieldNames,//输出key时是否使用双引号,默认为true
UseSingleQuotes,//使用单引号而不是双引号,默认为false
WriteMapNullValue,//是否输出值为null的字段,默认为false
WriteEnumUsingToString,//Enum输出name()或者original,默认为false
UseISO8601DateFormat,//Date使用ISO8601格式输出,默认为false
WriteNullListAsEmpty,//List字段如果为null,输出为[],而非null
WriteNullStringAsEmpty,//字符类型字段如果为null,输出为"",而非null
WriteNullNumberAsZero,//数值字段如果为null,输出为0,而非null
WriteNullBooleanAsFalse,//Boolean字段如果为null,输出为false,而非null
SkipTransientField,//如果是true,类中的Get方法对应的Field是transient,序列化时将会被忽略。默认为true
SortField,//按字段名称排序后输出。默认为false

@Deprecated
WriteTabAsSpecial,//把\t做转义输出,默认为false
PrettyFormat,//结果是否格式化,默认为false
WriteClassName,//序列化时写入类型信息,默认为false。反序列化是需用到
DisableCircularReferenceDetect,//消除对同一对象循环引用的问题,默认为false
WriteSlashAsSpecial,//对斜杠'/'进行转义
BrowserCompatible,//将中文都会序列化为\uXXXX格式,字节数会多一些,但是能兼容IE 6,默认为false
WriteDateUseDateFormat,//全局修改日期格式,默认为false。JSON.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd";JSON.toJSONString(obj, SerializerFeature.WriteDateUseDateFormat);
NotWriteRootClassName,//暂不知,求告知
DisableCheckSpecialChar,//一个对象的字符串属性中如果有特殊字符如双引号,将会在转成json时带有反斜杠转移符。如果不需要转义,可以使用这个属性。默认为false 
BeanToArray //暂不知,求告知
    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        super.configureMessageConverters(converters);
        FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
        FastJsonConfig fastJsonConfig = new FastJsonConfig();
        fastJsonConfig.setSerializerFeatures(SerializerFeature.BrowserCompatible,
                SerializerFeature.WriteNullListAsEmpty,
                SerializerFeature.PrettyFormat,
                SerializerFeature.WriteDateUseDateFormat,
                SerializerFeature.WriteNullStringAsEmpty,
                SerializerFeature.WriteMapNullValue,
                SerializerFeature.DisableCircularReferenceDetect);
        fastConverter.setFastJsonConfig(fastJsonConfig);
        converters.add(fastConverter);
    }`
### 如何在 Spring Boot 中集成 FastJSON2 实现 JSON 数据处理 #### 添加 Maven 依赖 要在 Spring Boot 项目中使用 FastJSON2 进行 JSON 处理,首先需要引入相应的 Maven 依赖。对于 `spring.boot` 版本为 2.x.x 和 Java 1.8 的环境,可以在项目的 `pom.xml` 文件中添加如下依赖: ```xml <dependency> <groupId>com.alibaba.fastjson2</groupId> <artifactId>fastjson2-extension-spring5</artifactId> <version>2.0.53</version> </dependency> ``` 此配置使得应用程序能够利用 FastJSON2 提供的功能来优化 JSON 序列化和反序列化的性能[^4]。 #### 配置 FastJSON2 作为默认 JSON 解析器 为了让 FastJSON2 成为 Spring Boot 默认使用的 JSON 工具,默认情况下会自动替换掉 Jackson 或其他内置的 JSON 解析工具。通常不需要额外编写任何代码即可完成这一设置;只需确保上述依赖项已正确定义并加载到类路径下即可生效。 如果希望进一步自定义 FastJSON2 行为,则可以通过创建一个名为 `FastJsonConfig.java` 的配置文件来进行更细致的调整。下面是一个简单的例子展示如何通过这种方式修改一些常见的选项: ```java import com.alibaba.fastjson2.support.config.FastJsonConfig; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class JsonConfiguration { @Bean public FastJsonConfig fastJsonConfig() { final FastJsonConfig fastJsonConfig = new FastJsonConfig(); // 设置日期格式 fastJsonConfig.setDateFormat("yyyy-MM-dd HH:mm:ss"); return fastJsonConfig; } } ``` 这段代码展示了怎样改变默认日期时间格式以及其他可能影响 JSON 输出样式的参数。 #### 使用 FastJSON2 API 编写业务逻辑 一旦完成了以上两步准备工作之后,在实际编码过程中就可以像平常一样调用 FastJSON2 提供的各种方法了。比如要将某个对象转成 JSON 字符串可以这样做: ```java import com.alibaba.fastjson2.JSON; // 假设有一个 User 类型的对象 userInstance String jsonString = JSON.toJSONString(userInstance); System.out.println(jsonString); // 打印出来的就是该用户的 JSON 形式表示 ``` 同样地,当接收到外部传来的 JSON 文本时也可以轻松将其还原回原始 POJO 对象: ```java User restoredObject = JSON.parseObject(jsonString, User.class); ``` 这些基本操作足以满足大多数日常开发需求,并且由于 FastJSON2 自身优秀的性能表现,因此非常适合用于构建高性能 Web 应用程序中的数据交互环节[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三棱球

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值