为什么rest接口返回json建议采用下划线形式,不要用驼峰
今天被数据大神说了,对接第三方接口返回的json字段我想用驼峰形式,他说我这样不专业。所以就改了,认怂。
记住以后再次对接rest接口,返回的字段用下划线形式
记录一下改的内容
1.使用fastjson的@JSONField(name="is_member")
如果没有fastjson的包,要先引入
com.alibaba fastjson 1.2.54
实体参数:
/** *是否会员 */ @JSONField(name="is_member") privateStringisMember;
将需要转换的实体都标注好后,在通过JSONObject转jsonString的时候,就可以得到字段为下户线的json了
Stringjson=JSONObject.toJSONString(newEntity());
tips:可以写个单元测试,测试一下这个转换是否成功
另外,还可以设置json转换时去掉某个字段,只需要这么写
@JSONField(serialize=false)
privateStringname;
自己写单元测试试一下吧
2.为了统一,csv文件的header字段我也用了下划线,但是由于这个不是转换json,所以上面的方法行不通,所以我自己转换了一下。
publicstaticfinalcharUNDERLINE='_'; /** *@Description驼峰式转下划线 */ publicstaticStringcamelToUnderline(Stringparam){ if(param==null||"".equals(param.trim())){ return""; } intlen=param.length(); StringBuildersb=newStringBuilder(len); for(inti=0;i好了,统一下划线格式就改好了。
补充知识:@JsonProperty注解和@Colume注解--驼峰式和下划线之间的自动转换
变量名为appid,希望jackson在把对象转换为json串时变为AppId。可以使用@JsonProperty注解
@JsonProperty("user_name")
privateStringuserName;
变量名为createTime,希望JPA自动对应到数据库的create_time字段,可以使用
@Column注解。 @Column(name="create_time") publicTimestampgetCreateTime(){ returncreateTime; }以上这篇为什么rest接口返回json建议采用下划线形式,不要用驼峰就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。