雪花算法⽣成ID传到前端之后精度丢失问题

雪花算法⽣成ID传到前端之后精度丢失问题,第1张

前段时间和前端联调的时候,发现前端收到的ID和传过去的ID不⼀致,⽐如数据库⾥的ID为1044297632316526592,传到前端就变成1044297632316526600;

服务器端实体类属性id类型为Long型,使⽤的是mongodb数据库,这都没什么问题。

出现这种问题的原因是,前端JS导致的id精度丢失的问题,
前端JSON字符串转js对象,接收Long类型的是Number,Number精度是16位(雪花ID是19位),JS的Number数据类型导致精度丢失。

解决办法一:直接使⽤@JsonSerialize注解
JsonSerialize注解可以帮我们实现字段值的序列化和反序列话,@JsonSerialize(using =

ToStringSerializer.class),代码如下:
public class Post{
    @ApiModelProperty(value = "帖⼦id")
    @JsonSerialize(using = ToStringSerializer.class)
    private Long postId;
    ...  
}

在需要解决数字过长的字段上添加@JsonSerialize注解就可以完美解决这⼀问题。

解决办法二:全局配置

@Configuration
@EnableWebMvc
public class WebMvcConfig implements WebMvcConfigurer {
	@Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        MappingJackson2HttpMessageConverter jackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter();
        ObjectMapper objectMapper = new ObjectMapper();
        // 全局配置序列化返回 JSON 处理
        SimpleModule simpleModule = new SimpleModule();
        // JSON Long ==> String  将所有的 Long类型 转换成 String类型 返回 
        simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
        objectMapper.registerModule(simpleModule);
        jackson2HttpMessageConverter.setObjectMapper(objectMapper);
        converters.add(jackson2HttpMessageConverter);
    }
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1297912.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-10
下一篇 2022-06-10

发表评论

登录后才能评论

评论列表(0条)

保存