雪花算法生成的ID在返回给前端之后和生成的不一样,到底是什么原因?

一、背景:

        最近在做项目的时候发现用雪花算法生成的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)

四、总结

        我用的最简单的注解方式,有补充的可以补充噢,互相学习!!!

你可能感兴趣的:(java,前端,java,javascript)