news 2026/6/3 14:01:54

Java后端接口字段命名转换:蛇形与驼峰式自动映射技术

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java后端接口字段命名转换:蛇形与驼峰式自动映射技术

结论先行:

前端统一 snake_case,后端统一 camelCase,由 Jackson 全局自动完成双向映射。

这是Jackson 层面的统一协议问题,不应该在 DTO/VO 上“手工处理”。

在 大项目体量里,必须做到全局自动转换、零侵入、零重复注解

一、核心机制:Jackson 命名策略(双向自动)

Jackson 原生支持序列化 & 反序列化同时生效

场景行为
Request JSON → Java DTOaccess_tokenaccessToken
Java VO → Response JSONaccessTokenaccess_token

无需在字段上写任何注解

二、推荐方案(全局配置,唯一入口)

1. application.yml(首选,最干净)

spring:jackson:property-naming-strategy:SNAKE_CASE

这一行就够了。

2. 等价 Java 配置(如果你偏代码化)

@ConfigurationpublicclassJacksonConfig{@BeanpublicObjectMapperobjectMapper(){ObjectMappermapper=newObjectMapper();mapper.setPropertyNamingStrategy(PropertyNamingStrategies.SNAKE_CASE);returnmapper;}}

建议用yml,避免 ObjectMapper 多实例污染。

三、示例:LoginRequest / LoginVO

1. LoginRequest(后端代码,驼峰)

publicclassLoginRequest{privateStringaccount;privateStringpassword;privateStringloginType;}

前端请求 JSON(下划线)

{"account":"13800138000","password":"123456","login_type":"PASSWORD"}

Jackson 自动映射为:

loginRequest.getLoginType();// PASSWORD

2. LoginVO(后端代码,驼峰)

publicclassLoginVO{privateStringaccessToken;privateStringrefreshToken;privateLongexpiresIn;}

返回给前端 JSON(自动下划线)

{"access_token":"xxx","refresh_token":"yyy","expires_in":7200}

四、为什么这是大项目必须采用的方式

1. 前端世界就是 snake_case

  • iOS / Android / 小程序 / OpenAPI
  • 多语言 SDK 生成器默认 snake_case
  • JSON Schema / OpenAPI 更友好

2. Java 世界必须 camelCase

  • Lombok / Bean 规范
  • MyBatis / MapStruct
  • IDE 自动补全

3. 中间层自动转换,才是工业级解法

五、禁止的“反模式”(踩一个就会后悔)

❌ 每个字段写 @JsonProperty

@JsonProperty("access_token")privateStringaccessToken;

问题:

  • DTO 爆炸
  • 重构成本极高
  • 其他开发人员一定骂你

❌ Request / Response 分两套字段名

privateStringaccess_token;

问题:

  • Java 规范被破坏
  • IDE / Lombok / Mapper 全部痛苦

六、特殊情况如何处理(白名单)

1. 单字段例外

@JsonProperty("openid")privateStringopenId;

只在:

  • 第三方强绑定字段
  • 历史兼容接口

2. 禁止自动转换的字段

@JsonNaming(PropertyNamingStrategies.LowerCamelCaseStrategy.class)publicclassThirdPartyCallbackRequest{}

七、与 Swagger / OpenAPI 的一致性

启用后:

  • Swagger 显示字段名:access_token
  • 后端字段:accessToken
  • 文档 = 实际接口

八、最终统一规范(一句话版)

后端代码只写驼峰;
API 协议只暴露下划线;
Jackson 全局负责翻译。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/2 15:06:49

隐形眼镜护理液浸泡的关键

使用护理液浸泡隐形眼镜并非只是倒一点、泡一泡那么简单,这一步做不对的话,镜片不干净不说,还可能伤眼睛。那么,浸泡过程中有哪些关键点需要大家注意的呢? 护理液的核心作用是清洁、杀菌以及保湿,全面保护和…

作者头像 李华
网站建设 2026/5/29 7:36:47

Obsidian主页定制终极指南:打造你的专属知识管理门户

还在为Obsidian杂乱无章的主页而烦恼吗?想要一个既美观又实用的知识管理门户吗?今天就来教你如何通过Farouks Homepage主题,快速打造个人专属的Obsidian主页。这个主题专为知识管理而设计,集成了卡片布局、动态进度条和智能倒计时…

作者头像 李华
网站建设 2026/6/2 3:09:27

三步完成InternLM3模型4bit量化:显存直降50%的终极部署指南

三步完成InternLM3模型4bit量化:显存直降50%的终极部署指南 【免费下载链接】InternLM Official release of InternLM series (InternLM, InternLM2, InternLM2.5, InternLM3). 项目地址: https://gitcode.com/gh_mirrors/in/InternLM 还在为AI大模型部署时爆…

作者头像 李华
网站建设 2026/6/3 5:49:50

fcitx5 vs ibus:中文输入法性能深度对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个输入法性能测试工具,功能包括:1. 测量输入法启动时间 2. 记录输入响应延迟 3. 统计内存和CPU占用 4. 测试词库加载速度 5. 生成可视化对比报告。要求…

作者头像 李华
网站建设 2026/6/1 14:36:49

智能简历解析终极指南:如何用AI技术精准提取关键信息

智能简历解析终极指南:如何用AI技术精准提取关键信息 【免费下载链接】Resume-Matcher Resume Matcher is an open source, free tool to improve your resume. It works by using language models to compare and rank resumes with job descriptions. 项目地址…

作者头像 李华
网站建设 2026/5/31 0:57:54

springAI学习 一

一、Spring AI 概述 什么是Spring AI? Spring生态的AI集成框架 统一API访问不同AI服务(OpenAI、Azure OpenAI、Anthropic等) 支持多种AI功能:聊天、文生图、嵌入、向量存储等 Spring AI 是一个用于 AI 工程的应用框架。 其目标…

作者头像 李华