首页> JAVASCRIPT教程
@JsonSerialize不起作用的解决方案
withpy
2021-10-29
简介这篇文章主要介绍了@JsonSerialize不起作用的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
@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<Integer> { @Override public 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()方法上。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持本站。
下一篇:浅谈Vue3 父子传值
相关文章
-
C语言实现简单的井字棋游戏
这篇文章主要为大家详细介绍了C语言实现简单的井字棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
-
pycharm 的Structure界面设置操作
这篇文章主要介绍了pycharm 的Structure界面设置操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
-
springboot动态定时任务的实现方法示例
这篇文章主要给大家介绍了关于springboot动态定时任务的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
-
关于Linux服务器配置java环境遇到的问题小结
这篇文章主要介绍了关于Linux服务器配置java环境遇到的问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
-
查看连接mysql的IP地址的实例方法
在本篇文章里小编给大家分享的是一篇关于查看连接mysql的IP地址的实例方法,有需要的朋友们可以参考下。
-
Pytorch 实现focal_loss 多类别和二分类示例
今天小编就为大家分享一篇Pytorch 实现focal_loss 多类别和二分类示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧