雪花算法生成的ID过长,前端接收精度丢失问题
时间:2024-04-27 17:55:24 来源:网络cs 作者:欧阳逸 栏目:广告工具 阅读:
今天在写项目时,前端反馈过来一个问题,get到的留言id和我给到前端的id不一致,说接口有问题,我一看不对啊,这些接口都测试过了的???
带着疑惑我看了他给到我的图:
很明显出现了精度缺失的问题!
问题现象:表的Id使用雪花算法生成,数据库使用bigint类型可以正常存储,后端使用Long类型也可以正常接收,postman进行请求测试,也可以看到后端正常返回的数据,但是前端接收后显示的id不正常。
而出现的原因:前端使用number类型进行接收,number类型的范围是16位而在项目中使用的雪花算法是19,这就导致后三位变成了000,出现了精度丢失问题!!!
在查阅资料之后找到了两种解决方案:
1.改后端
后端把返回参数id改为String类型,这样前端接收的就也是String类型,就不会有精度丢失问题
使用@JsonSerialize(using = ToStringSerializer.class)和@JsonDeserialize(using = ToLongSerializer.class)注解
@JsonSerialize(using = ToStringSerializer.class):是将Long类型的数据转为字符串类型,进而可以让前端使用String类型接收,解决精度丢失问题。
@JsonDeserialize(using = ToLongSerializer.class):是将String类型转换为Long类型,便于后台进行数据处理。ToLongSerializer类须手动编写代码实现。
2.改前端
导入JSONBigInt包
本文链接:https://www.kjpai.cn/news/2024-04-27/162999.html,文章来源:网络cs,作者:欧阳逸,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!
上一篇:Linux的Vi编辑器显示行数
下一篇:返回列表