①现象
后台:
前台:
②原因(百度的答案):
long类型继承的是number类,而number类型精度为16位(最大值:9007199254740992,这个值我有实际操作过,我查询的数据使用的类有Long类型字段id,我将一条数据的id字段值改的比这个小前后台是一致的,改的比这个值大前后台就有时不一致了),而雪花算法生成的id为19位,因此会导致精度丢失。
具体到我这里后台id是不是雪花算法不确定,但是位数是19位,超过了(9007199254740992)这个最大值。
③解决方案:
1>(未测试)后台不要用Long类型,改为String类型。
2>(未测试)通过添加一个全局配置来使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;
}
}
3>(测试确实会对Long类型起作用)在application.yml中加上以下配置,这个办法会将所有数字都变成字符串,包括long和int类型
spring:
jackson:
generator:
writeNumbersAsStrings: true
4>(未测试)在对应的字段上面添加注解
@JsonSerialize(using = ToStringSerializer.class)