当前位置: 首页 > ds >正文

消息转换器--通过此工具进行时间转换

在 Spring MVC 处理中,HttpMessageConverter 负责在 HTTP 报文与 Java 对象之间完成序列化/反序列化。
项目常见需求包括:统一 JSON 日期格式、过滤未知字段、为前端与后端提供一致的时间序列化策略等。
下文以截图中的代码为例说明 如何编写并注册自定义 JSON 消息转换器,并给出关键原理与最小可运行配置。


1 HttpMessageConverter 的职责与执行流程

要点说明参考
转换时机Spring MVC 在解析 @RequestBody 或生成 @ResponseBody 时,通过 HttpMessageConverter 完成 Java ↔ JSON/XML 映射Baeldungturn0search0
选择规则Spring 按 注册顺序 遍历转换器:第 1 个声明“我能处理当前媒体类型”即被选中,后续不再尝试Hometurn0search9
默认实现Spring Boot 自动装配了多种实现,JSON 部分由 MappingJackson2HttpMessageConverter 配合全局 ObjectMapper 完成Mediumturn0search8


2 为何需要自定义 JSON 转换器

  • Java 8 日期(LocalDateTime/LocalDate/LocalTime)默认序列化为 ISO-8601,如 2023-05-26T14:45:30

  • 业务常见格式为 yyyy-MM-dd HH:mm 等,需要统一输出/输入格式并容忍未知字段。

  • 通过自定义 ObjectMapper 并置于 首位,即可在不修改实体类的情况下实现全局控制Stack OverflowBaeldung。


3 代码拆解:extendMessageConverters

 

java

复制编辑

@Override protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) { // ① 构造 JSON 消息转换器 MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter(); // ② 注入自定义 ObjectMapper converter.setObjectMapper(new JacksonObjectMapper()); // ③ 插入 converters 第 0 位,确保优先匹配 converters.add(0, converter); }

步骤作用
创建基于 Jackson 的 JSON 转换器Java Code Geeks
替换默认 ObjectMapper,实现专用序列化策略
将转换器置于索引 0,确保 Spring 首先选择该实现Stack Overflow


4 自定义 JacksonObjectMapper 的关键设置

 

java

复制编辑

public class JacksonObjectMapper extends ObjectMapper { public static final String DATE_TIME_FMT = "yyyy-MM-dd HH:mm"; public static final String DATE_FMT = "yyyy-MM-dd"; public static final String TIME_FMT = "HH:mm:ss"; public JacksonObjectMapper() { // 1. 关闭未知字段失败 this.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); // 2. 注册自定义 (de)serializer SimpleModule module = new SimpleModule() .addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DATE_TIME_FMT))) .addSerializer (LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DATE_TIME_FMT))) .addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern(DATE_FMT))) .addSerializer (LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern(DATE_FMT))) .addDeserializer(LocalTime.class, new LocalTimeDeserializer(DateTimeFormatter.ofPattern(TIME_FMT))) .addSerializer (LocalTime.class, new LocalTimeSerializer(DateTimeFormatter.ofPattern(TIME_FMT))); this.registerModule(module); } }

  • 日期格式统一:通过 LocalDateTimeSerializer/Deserializer 指定业务格式Stack Overflow。

  • 容错设置FAIL_ON_UNKNOWN_PROPERTIES=false 避免前端字段冗余时抛异常Baeldung。


5 完整序列化流程示例

  1. 请求阶段

    • 前端发送 JSON:{"orderTime":"2023-11-01 12:30"}

    • 自定义转换器 → 反序列化为 LocalDateTime 对象,格式解析成功。

  2. 响应阶段

    • Controller 返回含时间字段的实体。

    • 同一转换器序列化 → JSON 输出 "2023-11-01 12:30" 而非 ISO-8601。

  3. 顺序保证

    • 若未在索引 0 插入,Spring 可能使用默认转换器,日期仍为 2023-11-01T12:30:00Stack Overflow。


6 实践注意事项

问题建议
多模块扫描若存在非业务 Controller,需调整 basePackage(),避免生成冗余接口文档。
与 Spring Boot 2.6+当引入 Spring MVC + Spring Boot 2.6+ 时,Springfox 可能不兼容;可升级至 springdoc-openapi + Knife4j 3.x。
性能自定义序列化器无需每次创建,可通过单例 ObjectMapper 复用。

http://www.xdnf.cn/news/15665.html

相关文章:

  • Mybatis-2快速入门
  • 【WRFDA数据教程第一期】LITTLE_R 格式详细介绍
  • 【源力觉醒 创作者计划】百度携文心 4.5 入局,开源大模型市场再添一员猛将,与 Qwen3 对比如何?
  • 3DGS之COLMAP
  • iOS 抓包工具选择与配置指南 从零基础到高效调试的完整流程
  • Android动态获取当前应用占用的内存PSS,Java
  • 汽车功能安全-相关项集成和测试(系统集成测试系统合格性测试)-12
  • 从电子管到CPU
  • 迁移学习的概念和案例
  • 【前端Vue】this.resetForm(“form“)重置表单时出现indexOf报错的解决方案
  • Java 增强 switch 语句详解:从基础到进阶的全面指南
  • Sersync和Rsync部署
  • Ubuntu 安装
  • 22-C#的委托简单使用-2
  • Linux715 磁盘管理:逻辑卷
  • MyBatis Plus功能增强全解析:从手写SQL到优雅开发的进阶指南
  • 【jvm|基本原理】第四天
  • Vue3入门-指令补充
  • MyBatis与Spring整合优化实战指南:从配置到性能调优
  • 《每日AI-人工智能-编程日报》--2025年7月15日
  • mongoDB的CRUD
  • C++ Boost Aiso TCP 网络聊天(服务端客户端一体化)
  • QGIS新手教程9:字段计算器进阶用法与批量处理技巧
  • 操作HTML网页的知识点
  • Linux下调试器gdb/cgdb的使用
  • Unity 多人游戏框架学习系列一
  • 23.将整数转换为罗马数字
  • 全局 WAF 规则:构筑 Web 安全的坚固防线
  • 设计模式一: 模板方法模式 (Template Method Pattern)
  • 基于 AI 的大前端安全态势感知与应急响应体系建设