fastjson自定义序列化和反序列化(扩展点)方法总结

文摘   2024-10-08 19:57   湖北  

在fastjson库中,为了提供灵活的序列化和反序列化机制,设计了一系列的扩展点。

1. 扩展点的用途

fastjson提供的这些扩展点使得我们可以根据实际需求定制序列化和反序列化的行为。如,可通过SerializeFilterParserProcess定制复杂的序列化和反序列化逻辑,通过SerializerFeatureParserFeature控制序列化和反序列化的输出格式和特性,以及p通过SerializeConfigParserConfig进行全局配置。

2. 序列化扩展点

2.1. SerializeFilter

  • 用途:用于在序列化过程中定制输出,如过滤某些字段、修改字段值等。
  • 使用方法
    • 实现SerializeFilter接口或其子接口(如SimplePropertyPreFilterPropertyFilter等)。
    • 在序列化时,通过JSON.toJSONString等方法的重载版本传入自定义的SerializeFilter实例。
SerializeFilter filter = new SimplePropertyPreFilter() {    @Override    public boolean accept(int index, JavaBeanSerializer beanSer, Object object, Object fieldName, Object fieldVal) {        // 定制序列化逻辑        return true; // 返回true表示保留该字段,false表示过滤    }};String jsonStr = JSON.toJSONString(obj, filter);

2.2. SerializerFeature

  • 用途:控制序列化的输出格式和特性。
  • 使用方法
    • 在序列化时,通过JSON.toJSONString等方法的重载版本传入SerializerFeature枚举值来控制序列化特性。
String jsonStr = JSON.toJSONString(obj, SerializerFeature.PrettyFormat); // 格式化输出

2.3.  SerializeConfig

  • 用途:全局配置序列化行为,如自定义序列化器、日期格式等。
  • 使用方法
    • 创建SerializeConfig实例并配置相关选项。
    • 在序列化时,通过JSON.toJSONString等方法的重载版本传入SerializeConfig实例。
SerializeConfig config = new SerializeConfig();// 配置...String jsonStr = JSON.toJSONString(obj, config);

2.4. 自定义序列化器(Serializer)

fastjson自定义序列化器,用于控制特定类型的序列化过程。用户需实现SerializerFeature接口,并重写write方法。

public class CustomSerializer implements SerializerFeature {    @Override    public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) throws IOException {        // 自定义序列化逻辑    }}

在序列化过程中,可通过SerializerFeature枚举值来指定使用自定义序列化器。

String jsonStr = JSON.toJSONString(obj, SerializerFeature.CustomSerializer, new CustomSerializer());

2.5. 序列化过滤器(SerializeFilter)

序列化过滤器用于在序列化过程中修改序列化结果。需实现SerializeFilter接口,并重写process方法。

public class CustomSerializeFilter implements SerializeFilter {    @Override    public boolean process(Object source, String name, Object value, SerializeFilter.Context context) {        // 自定义序列化过滤逻辑    }}

在序列化过程中,可通过JSON.toJSONString方法的重载版本传入自定义序列化过滤器。

String jsonStr = JSON.toJSONString(obj, new CustomSerializeFilter());

2.6. 自定义日期格式化

fastjson自定义日期格式。可通过SerializerFeature枚举值DisableCircularReferenceDetectWriteMapNullValue来指定日期格式。

String jsonStr = JSON.toJSONString(obj, SerializerFeature.DisableCircularReferenceDetect, SerializerFeature.WriteMapNullValue);

还可通过DateFormat属性来指定全局的日期格式。

JSON.setDateFormat(new StdDateFormat());

2. 反序列化扩展点

2.1. ParseProcess

  • 用途:在反序列化过程中执行额外逻辑,如修改反序列化结果。

  • 使用方法

    • 实现ParseProcess接口并重写其中的方法。
    • 在反序列化时,通过JSON.parseObject等方法的重载版本传入ParseProcess实例。
  1. ParserFeature
  • 用途:控制反序列化的行为和特性。
  • 使用方法
    • 在反序列化时,通过JSON.parseObject等方法的重载版本传入ParserFeature枚举值来控制反序列化特性。
Object obj = JSON.parseObject(jsonStr, Object.class, Feature.AllowSingleQuotes); // 允许使用单引号

2.2. ParserConfig

  • 用途:全局配置反序列化行为,如自定义反序列化器、自动类型转换等。
  • 使用方法
    • 创建ParserConfig实例并配置相关选项。
    • 在反序列化时,通过JSON.parseObject等方法的重载版本传入ParserConfig实例。
ParserConfig config = new ParserConfig();// 配置...Object obj = JSON.parseObject(jsonStr, Object.class, config);

代码

SerializeFilter用于过滤某些字段:

SerializeFilter filter = new SimplePropertyPreFilter() {    @Override    public boolean accept(int index, JavaBeanSerializer beanSer, Object object, Object fieldName, Object fieldVal) {        if ("password".equals(fieldName)) {            return false; // 过滤password字段        }        return true;    }};String jsonStr = JSON.toJSONString(user, filter);

2.3. 自定义反序列化器(Deserializer)

类似地,fastjson也支持自定义反序列化器。需要实现ObjectDeserializer接口,并重写deserialze方法。

public class CustomDeserializer implements ObjectDeserializer {    @Override    public Object deserialize(DefaultJSONParser parser, Type type, Object fieldName) {        // 自定义反序列化逻辑    }}

在反序列化过程中,可通过ParserConfig类的putDeserializer方法来注册自定义反序列化器。

ParserConfig.getGlobalInstance().putDeserializer(SomeType.class, new CustomDeserializer());

2.4. 解析过程(ParseProcess)

解析过程在反序列化过程中使用,可实现ParseProcess接口并重写process方法来自定义解析逻辑。

public class CustomParseProcess implements ParseProcess {    @Override    public Object process(ParseContext ctx) {        // 自定义解析逻辑    }}

在反序列化过程中,可以通过JSON.parseObject方法的重载版本传入自定义解析过程。

Object obj = JSON.parseObject(jsonStr, SomeType.class, new CustomParseProcess());

太强 ! SpringBoot中出入参增强的5种方法 : 加解密、脱敏、格式转换、时间时区处理

太强 ! SpringBoot中优化if-else语句的七种绝佳方法实战

SpringBoot使用EasyExcel并行导出多个excel文件并压缩zip下载
提升编程效率的利器: Google Guava库中双向映射BitMap
从MySQL行格式原理看:为什么开发规范中不推荐NULL?数据是如何在磁盘上存储的?
SpringBoot中使用Jackson实现自定义序列化和反序列化控制的5种方式总结
提升编程效率的利器: Google Guava库之RateLimiter优雅限流
深入JVM逃逸分析原理:且看其如何提高程序性能和内存利用率
必知必会!MySQL索引下推:原理与实战

深入解析JVM内存分配优化技术:TLAB

SpringBoot中基于JWT的双token(access_token+refresh_token)授权和续期方案
SpringBoot中基于JWT的单token授权和续期方案
SpringBoot中Token登录授权、续期和主动终止的方案(Redis+Token)
微服务中token鉴权设计的4种方式总结
提升编程效率的API利器:精通Google Guava库区间范围映射RangeMap
SpringBoot中Jackson控制序列化和反序列化的注解和扩展点总结【收藏版】

SpringBoot中大量数据导出方案:使用EasyExcel并行导出多个excel文件并压缩zip后下载

SpringBoot中基于XXL-JOB实现大量数据灵活控制的分片处理方案

              点赞 和 在看 就是最大的支持


码到三十五
主要分享正经的开发技术(原理,架构,实践,源码等),以输出驱动输入;当然偶尔会穿插点生活琐碎,顺便吃个瓜,目的嘛,搞点精准流量,看能不能发发广告。
 最新文章