雪花算法前台精度丢失解决方案

前言

雪花算法生成的Long型ID,传到前台时末尾精度丢失。后台数据1402848130449276928传到前台变为1402848130449277000。为了兼容先前代码。方案为:后台类型保持不变。jackson序列化数据到前台时,将Long转为String。前台使用String类型ID,既不影响前后台数据交互,也不影响前台大部分代码,我的前台系统代码也只是修改了分页插件的Total变量,将其再次转为Number类型。

后台序列化

第一种方案:
此种方案仅在系统中没有使用@EnableWebMvc注解时有效。
因为@EnableWebMvc继承的WebMvcConfigurationSupport,requestMappingHandlerAdapter()中的setMessageConverters会覆盖掉自定义的ObjectMapper。

 @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;
 }

第二种方案:
在@EnableWebMv注解的类中这样注册

@Override
public void extendMessageConverters(List<HttpMessageConverter<?>> converters){
    MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
    ObjectMapper objectMapper = converter.getObjectMapper();
    // 生成JSON时,将所有Long转换成String
    SimpleModule simpleModule = new SimpleModule();
    simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
    simpleModule.addSerializer(Long.TYPE, ToStringSerializer.instance);
    objectMapper.registerModule(simpleModule);
    // 设置格式化内容
    converter.setObjectMapper(objectMapper);
    converters.add(0, converter);
}

前台转化

几乎前台所有代码无需修改。你也可以用一元+操作符,将string转化为Number类型

this.page.totalCount = +data.totalCount

https://blog.csdn.net/myle69/article/details/87209297

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值