一、背景:
最近在做项目的时候发现用雪花算法生成的id传给前端以后跟生成的不一样,就纳闷,在想为什么会出现这样的问题?
二、问题分析:
最开始以为是被四舍五入了,上网查询后才发现是内部的问题,long类型继承的是number类,而number类型精度为16位,而雪花算法生成的id为19位,因此会导致进度丢失
三、直接上解决方案:
①如果想要前端不丢失精度,JSON中的id就不能是long类型,改为String类型就好了。
这个方案如果此id用的类少,就可以改id的数据类型,但是当用到的类多的话要改过来就需要花很长时间,并且不能保证都能改过来,而且不会出问题。
②通过添加一个全局配置来使long类型转为JSON中的string类型,省去了一个一个添加注解的麻烦。
@Configurationpublic class JacksonConfig {
@Bean
@Primary
@ConditionalOnMissingBean(ObjectMapper.class)
public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder)
{
ObjectMapper objectMapper = builder.createXmlMapper(false).build();
// 全局配置序列化返回 JSON 处理
SimpleModule simpleModule = new SimpleModule();
//JSON Long ==> String
simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
objectMapper.registerModule(simpleModule);
return objectMapper;
}
}
③在application.yml中加上以下配置,这个办法会将所有数字都变成字符串,包括long和int类型
spring:
jackson:
generator:
writeNumbersAsStrings: true
④在对应的字段上面添加注解
@JsonSerialize(using = ToStringSerializer.class)
四、总结
我用的最简单的注解方式,有补充的可以补充噢,互相学习!!!