目录
1. 添加必要依赖
首先确保项目中包含JSR-310支持模块:
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jsr310</artifactId>
<version>2.12.5</version> <!-- 版本需与项目中的Jackson版本匹配 -->
</dependency>
2. 配置全局序列化方案(推荐)
创建Jackson配置类统一处理时间类型:
@Configuration
public class JacksonConfig {
@Bean
public Jackson2ObjectMapperBuilderCustomizer jsonCustomizer() {
return builder -> {
// 设置全局日期格式
builder.simpleDateFormat("yyyy-MM-dd HH:mm:ss");
// 注册Java8时间模块
builder.modules(new JavaTimeModule());
// 禁用时间戳格式
builder.featuresToDisable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
};
}
}
3. 配置RabbitMQ消息转换器
在RabbitMQ配置中指定使用Jackson2JsonMessageConverter:
@Bean
public MessageConverter jsonMessageConverter() {
ObjectMapper objectMapper = new ObjectMapper()
.registerModule(new JavaTimeModule())
.disable(SerializationFeature.WRITE_DATES_AS_TIMESTAMPS);
return new Jackson2JsonMessageConverter(objectMapper);
}
关键点说明
- 版本兼容性:确保
jackson-datatype-jsr310
版本与其他Jackson组件版本一致 - 时间格式:禁用时间戳格式(
WRITE_DATES_AS_TIMESTAMPS
)可避免输出数字时间戳 - 微服务场景:该方案同样适用于其他Spring组件如RestTemplate/Feign的序列化