Spring Boot 4 全面拥抱 Jackson 3

Spring Boot 4 将默认 JSON 库从 Jackson 2 切换到了 Jackson 3

如果你是资深 Spring Boot 应用开发者,Jackson 一定不陌生,它是 Spring Boot 中 Java 对象 ↔ JSON 的事实标准。

Jackson 在 Spring Boot 4 中依赖结构大致是这样:

复制代码
spring-boot-starter-jackson (4.x)├── tools.jackson.core:jackson-core:3.x   ← Jackson 核心库└── com.fasterxml.jackson.annotation:jackson-annotations:2.x ← Jackson 注解

所以很多人在第一次查看项目依赖树时都会愣一下:

为什么项目里同时存在 Jackson 2 和 Jackson 3?

这是 Jackson 团队为了解决一个非常现实的问题:

整个 Java 生态不可能一夜之间全部迁移到 Jackson 3

他们的解决方案是:

核心实现迁移到新包名注解继续沿用旧包名

这意味着:

@JsonView@JsonFormat@JsonIgnore•......

这些你用烂了的注解 完全不用改, 可以让多个项目在 Jackson 2 / 3 之间渐进式迁移。

这是一次非常工程化、也非常现实的设计。

Spring Boot 4 默认升级到 Jackson 3 后,并不是 换个版本号这么简单。 下面这 4 个变化,每一个都可能在升级时踩坑。

1. 包名变了:从 com.fasterxml.jacksontools.jackson

这是最直观、也是最容易编译报错的地方。

复制代码
// Jackson 2import com.fasterxml.jackson.databind.ObjectMapper;// Jackson 3import tools.jackson.databind.ObjectMapper;

注意:

只有核心 API 换包名,注解依然在 com.fasterxml.jackson.annotation

2. ObjectMapper 退出舞台,JsonMapper 成为主角

Jackson 2 的 ObjectMapper可变的

​​​​​​​

复制代码
ObjectMapper mapper = new ObjectMapper();mapper.enable(SerializationFeature.INDENT_OUTPUT);

这在多线程环境下其实并不安全。

Jackson 3 强制你使用 Builder + Immutable(不可变) 模式:

​​​​​​​

复制代码
JsonMapper mapper = JsonMapper.builder()    .enable(SerializationFeature.INDENT_OUTPUT)    .disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES)    .build();

一旦 build()

•配置被锁死•可以安全共享•天然线程安全

这是 Jackson 3 非常重要的一次设计升级。

Jackson 3 直接创建的 ObjectMapper 只能得到默认配置,如果需要自定义配置,必须使用 JsonMapper.builder() 来创建不可变、线程安全的实例。

3. 日期序列化的默认值变了(非常容易踩坑)

版本 默认序列化
Jackson 2 时间戳
Jackson 3 ISO-8601 字符串

​​​​​​​

复制代码
// Jackson 2{"nowDate": 1767588151648}// Jackson 3{"nowDate": "2026-01-05T02:02:31.648Z"}

这对前端更友好,但会导致:

•依赖时间戳断言的老测试用例失败•与时间格式强绑定的接口约定、Mock 数据需要同步调整

临时兼容方案:

​​​​​​​

复制代码
spring:  jackson:    use-jackson2-defaults: true

该配置会让 Jackson 3 尽量保持 Jackson 2 的默认行为,适合在迁移初期使用。

4. Checked Exception 终于被干掉了

这是很多 Java 开发者拍手叫好的改动。

Jackson 2:

​​​​​​​

复制代码
try {    objectMapper.readValue(json, MyClass.class);} catch (IOException e) {    ...}

Jackson 3:

复制代码
jsonMapper.readValue(json, MyClass.class);

所有异常都继承自 JacksonExceptionRuntimeException)。

最直接的好处是:

​​​​​​​​​​​​​​

复制代码
// Jackson 2:lambda 直接崩list.stream()    .map(o -> objectMapper.writeValueAsString(o))    .toList();// Jackson 3:完全没问题list.stream()    .map(o -> jsonMapper.writeValueAsString(o))    .toList();

这是真正 为现代 Java 写法服务 的设计。

相关推荐
oem1104 分钟前
C++中的访问者模式变体
开发语言·c++·算法
aircrushin4 分钟前
端到端AI决策架构如何重塑实时协作体验?
前端·javascript·后端
Fu-dada6 分钟前
Spring Boot 开发接口指南
spring boot
苦瓜小生12 分钟前
【黑马点评学习笔记 | 实战篇 】| 6-Redis消息队列
redis·笔记·后端
SuperEugene27 分钟前
JS/TS 编码规范实战:Vue 场景变量 / 函数 / 类型标注避坑|编码语法规范篇
开发语言·javascript·vue.js
暮冬-  Gentle°27 分钟前
C++中的工厂方法模式
开发语言·c++·算法
大傻^32 分钟前
LangChain4j Spring Boot Starter:自动配置与声明式 Bean 管理
java·人工智能·spring boot·spring·langchain4j
沐硕34 分钟前
《基于改进协同过滤与多目标优化的健康饮食推荐系统设计与实现》
java·python·算法·fastapi·多目标优化·饮食推荐·改进协同过滤
yhole40 分钟前
springboot 修复 Spring Framework 特定条件下目录遍历漏洞(CVE-2024-38819)
spring boot·后端·spring
大傻^41 分钟前
Spring AI 2.0 MCP 协议实战:Model Context Protocol SDK 与多服务器编排
服务器·人工智能·spring