@JsonSerialize不起作用的解决方案
目录
- @JsonSerialize不起作用
- 在项目中 当字段实体类为Long类型时
- 但是这里有个小坑
- @JsonSerialize正确使用
- 1. 写一个负责转换的类
- 2. 在实体类上需要装换的字段上加上注解
@JsonSerialize不起作用
在项目中 当字段实体类为Long类型时
如果Long值超过前端js显示的长度范围时会导致前端回显错误
此时我们想到的解决方案是将Long值返回给前端时转为String,
但是我们又不想变更字段的类型,当然我们也不想额外添加新的字段。
这个时候我们可以用@JsonSerialize,在Json序列化的时候把Long自动转为String,
但是这里有个小坑
被转换的字段必须是包装类类型,否则会转换失败。
@JsonSerialize(using = ToStringSerializer.class)private Long parentId; //转化成功
@JsonSerialize(using = ToStringSerializer.class)private long parentId; //转化失败
@JsonSerialize正确使用 实际开发中,我们一定遇到过这样的问题:前端显示和后台存储数据单位不统一,而且各有各自的理由,统一不了,那就只能由后端转换。
每次返回给前端时再转换一遍,返回给前端的json数据,在后端里定义的往往是一个对象,如何做到优雅的转换呢?只需两步操作:
1. 写一个负责转换的类
里面写好规则
public class MySerializerUtils extends JsonSerializer{@Overridepublic void serialize(Integer status, JsonGenerator jsonGenerator, SerializerProvider serializerProvider) throws IOException, JsonProcessingException {String statusStr = ""; switch (status) {case 0:statusStr = "新建状态"; break; case 1:statusStr = "就绪状态"; break; case 2:statusStr = "运行状态"; break; case 3:statusStr = "阻塞和唤醒线程"; break; case 4:statusStr = " 死亡状态"; break; default:statusStr = "状态信息不符合"; }jsonGenerator.writeString(statusStr); } }
2. 在实体类上需要装换的字段上加上注解
/** * 多线程生命周期状态值 */@JsonSerialize(using = MySerializerUtils.class)private int status;
注:@JsonSerialize注解,主要应用于数据转换,该注解作用在该属性的getter()方法上。
【@JsonSerialize不起作用的解决方案】以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- 急于表达——往往欲速则不达
- 2018-02-06第三天|2018-02-06第三天 不能再了,反思到位就差改变
- 家乡的那条小河
- 一个人的碎碎念
- 赠己诗
- 这辈子我们都不要再联系了
- 死结。
- 我从来不做坏事
- 时间老了
- 我错了,余生不再打扰