JSON 框架混用避坑指南:FastJSON vs Jackson


一、问题定位

com.alibaba.fastjson.JSON.parseObject() 方法无法识别 Jackson 的 @JsonProperty 注解,导致字段映射失败。
核心矛盾:FastJSON 无法识别 Jackson 的 @JsonProperty 注解


二、框架对比表

特性 FastJSON Jackson
字段映射注解 @JSONField(name = "xxx") @JsonProperty("xxx")
反序列化方法 JSON.parseObject(json, Class) ObjectMapper.readValue(json, Class)
是否支持 Jackson 注解 ❌ 不支持 ✅ 支持
是否支持 FastJSON 注解 ✅ 支持 ❌ 不支持

三、典型错误场景

// 使用 Jackson 注解的类
public class User {
    @JsonProperty("user_name") // FastJSON 会忽略该注解
    private String name;
}

// FastJSON 反序列化失败
String json = "{\"user_name\": \"Alice\"}";
User user = JSON.parseObject(json, User.class); // name 字段为 null

四、解决方案

✅ 方案一:使用 FastJSON 原生注解

适用场景:项目以 FastJSON 为主

public class User {
    @JSONField(name = "user_name")
    private String name;
}

// 正确反序列化
User user = JSON.parseObject("{\"user_name\": \"Alice\"}", User.class);

✅ 方案二:统一使用 Jackson 框架

适用场景:项目需兼容 Jackson 注解

import com.fasterxml.jackson.databind.ObjectMapper;
public class User {
    @JsonProperty("user_name") // FastJSON 会忽略该注解
    private String name;
}
String json = "{\"user_name\": \"Alice\"}";
ObjectMapper mapper = new ObjectMapper();
// 关键配置:禁用未知字段校验
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
User user = mapper.readValue(json, User.class); // 自动识别 @JsonProperty


五、Maven 依赖建议

<!-- fastjson 依赖(方案一需要) -->
<dependency>
    <groupId>com.alibaba.fastjson2</groupId>
    <artifactId>fastjson2</artifactId>
    <version>2.0.42</version>
</dependency>
<!-- Jackson 依赖(方案二需要) -->
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.16.1</version>
</dependency>

六、关键总结

  1. 注解专属性:FastJSON 仅识别 @JSONField,Jackson 仅识别 @JsonProperty
  2. 框架隔离原则:避免在同一个类中混用两种注解,易引发不可预期的行为。
posted @ 2025-09-27 12:30  进击的小蔡鸟  阅读(20)  评论(0)    收藏  举报