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

4 篇文章 0 订阅

一、前言

最近在做项目的时候发现用雪花算法生成的id传给前端以后跟生成的不一样,就纳闷,在想为什么会出现这样的问题?

二、问题描述:

雪花算法生成id为16位,返回到前端之后后两位变为0

从两个点出发:

1.第一次想到的是四舍五入,仔细检查了也不是四舍五入,有些比5大的数也变为0了。

2.查Long类型和String类型数据长度。

上网查了一下,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)

我本次解决采用的是将id转为String类型,因为在项目中这个字段用到的少,容易修改,也不会影响其他功能。

  • 12
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值