SpringBoot的Json转换大小写的坑

最近搞了一个Springboot+mybatis的框架,往前端进行Json格式转换的时候,发现属性的大写首字母变小写了,这极大的不方便前后一致性,如是网上一堆乱搜,测试了N多情况,算是把问题解决了,不过坑大,记录如下:

1) 如果没有使用fastjson(阿里巴巴出品),使用@JsonProperty("XXXX")的注解方式可以解决问题,XXXX就是转换成Json的属性名,但注意,只有放在getter上才是有效的,直接在属性上加没效果.(这说明spring 默认的jackson类库处理是基于访问器。

2)如果使用了fastjson,就用@JSONField(name="XXXXX")注解方式进行,这个可以放在属性上。不过放在getter,setter上更好。

3)如果同时有两个存在,一般都是fastjson起效果,不过具体情况可以试下,我遇到的就是fastjson起效。当然要强制失效fastjson,就需要在Application类上加注解:@EnableWebMvc.

总结,初次为大规模做Java项目,开发底层框架,感觉Java的很多框架开发者有点死脑筋,命名规范这玩意就是个规范,你做框架底层没必要越厨代庖,强制采用这些规范。做底层的东西就要把自由度留给使用人员,别人才好在此基础上扩展。虽然可以通过一些注解什么的解决问题,但浪费很多时间。

整体上来说,无论是Java的一些框架还是语法本身都跟C#不在一个自由度上,很多时候都是做些没有什么技术含量的东西。

 
 
### 关于Spring Boot实体类属性名称与入参大小写的规则 在Spring Boot中,实体类的属性名称与请求参数之间的映射关系主要依赖于框架内部的自动绑定机制以及序列化/反序列化的实现方式。以下是关于此问题的具体说明: #### 自动绑定机制 当通过HTTP请求传递参数到控制器层的方法时,Spring Boot会尝试将请求中的键值对与方法参数或实体类属性进行匹配。这种匹配基于Java Bean规范,默认情况下遵循驼峰命名法(camelCase)与下划线命名法(snake_case)之间的隐式转换规则[^1]。 如果前端发送的数据采用的是`snake_case`风格(如`user_name`),而后端定义的实体类使用了`camelCase`风格(如`userName`),那么Spring Boot能够自动完成两者间的映射,前提是字段语义相同且仅存在大小写差异或者简单的分隔符区别。 然而,在某些场景下可能会遇到大小写不一致引发的问题,比如JSON响应对象内的字段名被意外修改成全部小写字母形式。这通常是因为Jackson库处理过程中未正确识别原始声明的名字所致[^3]。 #### 显式的注解控制 为了确保前后端交互的一致性和灵活性,可以利用特定注解来显式指定如何解析和生成JSON数据中的字段名称。例如,对于那些需要严格对应固定外部API契约的情况,可以在getter方法上加上`@JsonProperty("期望的名字")`标签,从而强制规定无论内部变量怎么定义,最终对外展现都遵照设定好的标准。 另外,针对数据库操作层面可能存在的表结构设计偏好(常用全小写的列标识),可以通过ORM工具提供的额外选项解决实体成员同DB字段不符的情形。像MyBatis就允许开发者借助XML映射文件里的resultMap元素或是全局配置typeAliases简化此类关联设置过程[^2]。 综上所述,虽然理论上不必绝对要求二者完全一样,但从维护成本和技术风险角度考虑,建议尽可能让双方约定好统一的标准并贯彻执行下去。 ```java // 示例代码展示如何应用@JsonProperty调整输出格式 import com.fasterxml.jackson.annotation.JsonProperty; public class User { private int uId; private String uName; private long uTime; @JsonProperty("uId") public int getUid() { return this.uId; } public void setUid(int uid){ this.uId = uid; } ... } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值