记一次SpringBoot传给前端Long类型精度丢失

前言

最近在做项目的时候,遇到了一个Long类型传给前端之后,接收到的数值不对的情况,我一开始以为是前端接收数据有问题,后来经过查找,了解到这是一个Long类型精度丢失问题,于是写这篇文章记录下来,也探究一下为什么会发生这种情况。

背景

  • 后端:Java、SpringBoot......
  • 前端:JavaScript、Vue......

问题展示

接口展示

数据响应展示:

浏览器预览展示:

问题原因

  • Java中,Long类型为64位有符合整数,取值范围是-2^63到2^63-1。

  • JavaScript中,所有数字均基于IEEE 754的双精度浮点数标准,其安全的整数范围是-(2^53-1)到2^53-1。

    超出最大数值的时候Long类型就会精度丢失。

问题解决方案

在SpringBoot将数据传给前端前,会默认使用Jackson序列化Java对象为JSON,Long类型默认将其转换成Number类型,到Long类型的数值超过Javas安全范围的数值时就会发生精度丢失,


方案一:使用@JsonSerialize注解

在你需要处理的字段添加注解。 实现如下面代码所示:

java 复制代码
 @Data
 public class Book {
       @JsonSerialize(using = ToStringSerializer.class)
       private Long id;  // 主键ID
       private String name;
   }

方案二:全局配置

将全部Long类型统一处理。实现如下面代码所示:

java 复制代码
@Configuration
public class JacksonConfig {

    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        SimpleModule simpleModule = new SimpleModule();
        // 将Long类型序列化为String类型
        simpleModule.addSerializer(Long.class, ToStringSerializer.instance);
        objectMapper.registerModule(simpleModule);
        return objectMapper;
    }
}

总结

上面两种方案都是将Long类型转换成String类型,前端使用String类型来保存保持精度不发生丢失问题。开始我遇到这个问题的时候,我直接认为是前端代码写的有问题,所有接到的数据才会出现问题,因为我knife4j响应的数据没有问题,结果前端自己搞来搞去了很久,找了其他人,之后才有人说是这个问题,当时的自己实际上是第一次前端后端一起合作开发一个小项目,给我的感受就是有许许多多的问题是只有在实践中才会发现的,而不是坐在大学的课堂中去学,而应该自己主动的去进行技术学习,然后将学的知识运用在开发中,许许多多的问题是只有自己遇到了,才会记忆犹新,并且通过自己解决,下次遇到就有应对之法。

相关推荐
大鸡腿同学4 小时前
【成长类】《只有偏执狂才能生存》读书笔记:程序员的偏执型成长地图
后端
0xDevNull4 小时前
MySQL数据冷热分离详解
后端·mysql
一定要AK4 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao4 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
AI袋鼠帝4 小时前
OpenClaw(龙虾)最强开源对手!Github 40K Star了,又一个爆火的Agent..
后端
KevinCyao4 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
迷藏4944 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
wuxinyan1235 小时前
Java面试题47:一文深入了解Nginx
java·nginx·面试题
新知图书5 小时前
搭建Spring Boot开发环境
java·spring boot·后端
冰河团队6 小时前
一个拉胯的分库分表方案有多绝望?整个部门都在救火!
java·高并发·分布式数据库·分库分表·高性能