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

前言

雪花算法生成的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

上一篇:Cesium应用篇:3控件(1)Clock


下一篇:Ajax