场景
前端展示一个id字段,使用此id字段查询另外一个表的数据,但是前端展示的id和后端传递的id值不一致
排查
- 后端传递的值的确是对的
- 在f12中看到前端接受的值也是对的
- 但是在前端展示的数据就是错误
原因
- 后端使用的id是雪花算法生成的,使用的类型是Long类型,是19位
- 前端接受并展示的时候,使用的类型是number类型,是16位
- 前端的精度比后端小,就会造成精度丢失
解決方案
- 如果項目中沒有fastjson依赖,先添加依赖
2、在项目的pom.xml文件中,添加fastjson的依赖
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.76</version>
<exclusions>
<exclusion>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</exclusion>
</exclusions>
</dependency>
- 在对应的id字段上加注解,前后端传递此字段,序列化的时候使用String类型,不要使用Long类型
@TableId(type = IdType.ASSIGN_ID)
@JsonSerialize(using = ToStringSerializer.class)
private Long id;