Long类型前后端数据不一致

响应给前端的数据浏览器控制台中response中看到的Long类型的数据是正常的到前端 数据不一致

前后端数据类型不匹配是一个常见问题,尤其是当后端使用Java的Long类型(64位)与前端JavaScript的Number类型(最大安全整数为2^53-1,即16位)进行数据交互时,很容易出现精度丢失的问题。这是因为JavaScript中的Number类型无法安全地表示超过16位的整数。

为了解决这个问题,可以采取以下几种方法:

  1. 后端将Long类型转换为String类型 :这是最常用的解决方法。在后端序列化JSON时,将Long类型的字段转换为String类型,这样前端接收到的数据就是字符串形式,避免了精度丢失的问题。可以通过在Java实体类中使用@JsonSerialize(using = ToStringSerializer.class)注解或者@JsonFormat(shape = JsonFormat.Shape.STRING)注解来实现这一转换。

  2. 全局配置Jackson :在Spring Boot项目中,可以通过配置Jackson的ObjectMapper来全局设置所有Long类型字段序列化为String类型。例如,通过SimpleModule注册一个自定义的序列化器,将Long类型转换为String类型。

  3. 前端处理:虽然不推荐,但在前端也可以通过一些方法来处理这种情况,比如使用BigInt或者在接收到数据后立即将其转换为字符串。

  4. 使用其他库 :例如,使用alibaba的fastJSON工具包,可以在实体类中,在Long类型的字段上加@JSONField(serializeUsing= ToStringSerializer.class)来实现转换。

  5. 数据库和缓存一致性:在某些情况下,可能还需要考虑数据库和缓存之间的一致性问题。可以采用先更新数据库再删除缓存的策略,或者使用版本号和分布式锁来确保数据一致性。

相关推荐
cs_dn_Jie20 分钟前
钉钉 H5 微应用 手机端调试
前端·javascript·vue.js·vue·钉钉
开心工作室_kaic1 小时前
ssm068海鲜自助餐厅系统+vue(论文+源码)_kaic
前端·javascript·vue.js
有梦想的刺儿1 小时前
webWorker基本用法
前端·javascript·vue.js
cy玩具2 小时前
点击评论详情,跳到评论页面,携带对象参数写法:
前端
qq_390161772 小时前
防抖函数--应用场景及示例
前端·javascript
John.liu_Test3 小时前
js下载excel示例demo
前端·javascript·excel
Yaml43 小时前
智能化健身房管理:Spring Boot与Vue的创新解决方案
前端·spring boot·后端·mysql·vue·健身房管理
PleaSure乐事3 小时前
【React.js】AntDesignPro左侧菜单栏栏目名称不显示的解决方案
前端·javascript·react.js·前端框架·webstorm·antdesignpro
哟哟耶耶3 小时前
js-将JavaScript对象或值转换为JSON字符串 JSON.stringify(this.SelectDataListCourse)
前端·javascript·json
getaxiosluo3 小时前
react jsx基本语法,脚手架,父子传参,refs等详解
前端·vue.js·react.js·前端框架·hook·jsx