雪花算法生成的ID过长,前端接收精度丢失问题

作者 : admin 本文共668个字,预计阅读时间需要2分钟 发布时间: 2024-02-29 共2人阅读

今天在写项目时,前端反馈过来一个问题,get到的留言id和我给到前端的id不一致,说接口有问题,我一看不对啊,这些接口都测试过了的???

带着疑惑我看了他给到我的图:

雪花算法生成的ID过长,前端接收精度丢失问题插图

雪花算法生成的ID过长,前端接收精度丢失问题插图(1) 

很明显出现了精度缺失的问题!

问题现象:表的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包

雪花算法生成的ID过长,前端接收精度丢失问题插图(2)

雪花算法生成的ID过长,前端接收精度丢失问题插图(3)

本站无任何商业行为
个人在线分享 » 雪花算法生成的ID过长,前端接收精度丢失问题
E-->