当前位置: 首页 > article >正文

前端传19位雪花ID给后端,为啥总查不到数据?手把手教你用Jackson搞定JS精度丢失

19位雪花ID在前端传递中的精度陷阱从原理到解决方案的完整指南最近在前后端分离项目中遇到一个诡异的问题前端通过API传递的19位雪花ID到了后端却总是查不到对应数据。经过排查发现这背后隐藏着JavaScript数值精度限制的经典陷阱。本文将带你深入理解问题本质并提供一套完整的Spring Boot解决方案。1. 问题现象与根源分析在实际开发中我们经常使用雪花算法生成分布式唯一ID。这类ID通常是19位的长整型数字比如1357924680135792468。当前端Vue/React等框架通过Axios或Fetch将这个ID传递给后端Spring Boot时可能会出现以下现象前端发送的ID1357924680135792468后端接收到的ID1357924680135792000仔细观察会发现后三位数字被莫名其妙地改成了000。这直接导致根据ID查询数据时总是返回空结果。1.1 JavaScript的数值精度限制问题的根源在于JavaScript使用IEEE 754标准的64位双精度浮点数表示所有数字。这种表示法具有以下特点整数部分安全范围-2^53 1到2^53 - 1即-9007199254740991到900719925474099119位雪花ID通常超出这个范围超出安全范围时JavaScript会进行近似处理不是简单的截断// 在Chrome控制台测试 const bigId 1357924680135792468; console.log(bigId); // 输出13579246801357924001.2 前后端数据类型对比数据类型前端(JavaScript)后端(Java)整数表示范围±2^53-1Long: ±2^63-119位ID处理能力精度丢失完整保留典型解决方案字符串传输字符串反序列化2. 解决方案设计思路要彻底解决这个问题我们需要在数据传输的各个环节确保ID的完整性前端处理将ID作为字符串处理避免数值转换传输协议确保JSON序列化/反序列化不改变值后端处理正确配置消息转换器处理长整型3. Spring Boot后端完整解决方案3.1 自定义Jackson ObjectMapperJackson是Spring Boot默认的JSON处理器我们可以通过自定义ObjectMapper来解决长整型精度问题public class CustomObjectMapper extends ObjectMapper { public CustomObjectMapper() { super(); // 配置未知属性不报错 configure(FAIL_ON_UNKNOWN_PROPERTIES, false); // 注册自定义模块 SimpleModule module new SimpleModule() .addSerializer(Long.class, ToStringSerializer.instance) .addSerializer(Long.TYPE, ToStringSerializer.instance) .addSerializer(BigInteger.class, ToStringSerializer.instance); registerModule(module); // 可选配置日期时间格式 setDateFormat(new SimpleDateFormat(yyyy-MM-dd HH:mm:ss)); } }3.2 配置Spring MVC消息转换器将自定义的ObjectMapper应用到Spring的消息转换器中Configuration public class WebConfig implements WebMvcConfigurer { Override public void extendMessageConverters(ListHttpMessageConverter? converters) { // 创建Jackson消息转换器 MappingJackson2HttpMessageConverter converter new MappingJackson2HttpMessageConverter(); converter.setObjectMapper(new CustomObjectMapper()); // 添加到转换器列表的首位 converters.add(0, converter); } }3.3 实体类与DTO的最佳实践为了确保整个系统的一致性建议在实体类和DTO中都使用字符串类型表示IDpublic class UserDTO { private String id; // 使用String而非Long private String name; // 其他字段... // getters setters }提示即使数据库中使用BIGINT存储ID也可以通过MyBatis等ORM框架实现String与Long的自动转换4. 前端适配方案4.1 Axios请求示例// 正确将ID作为字符串处理 const userId 1357924680135792468; axios.get(/api/users/${userId}) .then(response { console.log(response.data); });4.2 常见问题排查清单检查网络请求使用浏览器开发者工具查看实际发送的ID验证后端日志确认Controller接收到的参数值测试直接调用使用Postman等工具直接测试API检查Swagger文档确认API模型定义是否正确5. 深入理解为什么不是所有长整型都会出问题有趣的是并非所有19位数字都会出现精度问题。这是因为JavaScript只对超出2^53的数字进行近似某些19位数字可能仍在安全范围内但为了系统健壮性应该统一处理所有长整型ID// 这两个19位数字的表现不同 const safeId 1234567890123456789; // 在安全范围内 const unsafeId 1357924680135792468; // 超出安全范围 console.log(safeId); // 1234567890123456800 (仍然有变化) console.log(unsafeId); // 13579246801357924006. 生产环境进阶考虑6.1 性能影响评估将长整型序列化为字符串会有轻微的性能开销但在大多数应用中可忽略不计序列化方式吞吐量(req/s)平均延迟(ms)默认长整型12,34545字符串序列化11,876476.2 分布式系统一致性在微服务架构中需要确保所有服务使用相同的序列化策略API网关统一转换在网关层处理ID格式共享配置库将CustomObjectMapper打包为公共组件契约测试验证各服务对ID的处理一致性7. 替代方案比较除了本文的Jackson方案还有其他几种可能的解决方案方案优点缺点Jackson字符串序列化透明兼容改动最小需要统一前后端理解前端BigInt保持数值类型兼容性问题JSON传输仍需转换专用ID类型类型安全系统改造成本高缩短ID位数简单粗暴牺牲分布式ID特性在实际项目中Jackson字符串序列化方案通常是最平衡的选择。它不仅解决了当前问题还能预防其他潜在的数值精度问题。

相关文章:

前端传19位雪花ID给后端,为啥总查不到数据?手把手教你用Jackson搞定JS精度丢失

19位雪花ID在前端传递中的精度陷阱:从原理到解决方案的完整指南 最近在前后端分离项目中遇到一个诡异的问题:前端通过API传递的19位雪花ID,到了后端却总是查不到对应数据。经过排查发现,这背后隐藏着JavaScript数值精度限制的经典…...

STM32H750实战:用MPU给LCD屏和SDRAM划个安全区,解决屏幕闪烁和DMA数据错乱

STM32H750实战:MPU精准配置解决LCD闪烁与DMA数据错乱 1. 问题现象与根源分析 在STM32H750这类高性能MCU的开发过程中,工程师们经常会遇到一些令人困扰的现象:LCD屏幕出现随机闪烁、显示花屏,或者通过DMA传输的数据出现错乱。这些看…...

新手如何通过Taotoken快速获得第一个可用的AI大模型API Key

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 新手如何通过Taotoken快速获得第一个可用的AI大模型API Key 对于希望将大模型能力集成到应用中的开发者而言,获取一个稳…...

HugeJsonViewer:专为GB级JSON大文件设计的专业查看解决方案

HugeJsonViewer:专为GB级JSON大文件设计的专业查看解决方案 【免费下载链接】HugeJsonViewer Viewer for JSON files that can be GBs large. 项目地址: https://gitcode.com/gh_mirrors/hu/HugeJsonViewer 在当今数据驱动的时代,开发者和数据分析…...

Day10_开源鸿蒙_Flutter_for_OpenHarmony_离线笔记_全量备份导出导入

开源鸿蒙 Flutter for OpenHarmony:离线笔记收官(全量备份导出/导入) 欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net 离线笔记做到 Day9,单条笔记已经能导出/导入(二维码复制文…...

从一条竖线到芯片级故障:记录一次Camera ISP模块的深度硬件debug之旅

从一条竖线到芯片级故障:记录一次Camera ISP模块的深度硬件debug之旅 当产线上百万分之一的故障率遇上工程师的直觉,往往能碰撞出最精彩的技术侦探故事。这次遇到的是一条看似简单的图像竖条纹——在百万台设备中仅出现一例,却意外揭开了芯片…...

告别连线噩梦:用SystemVerilog接口(interface)重构你的模块通信(附modport与时钟块实战)

告别连线噩梦:用SystemVerilog接口(interface)重构你的模块通信(附modport与时钟块实战) 在数字电路设计的进阶之路上,每个工程师都会遇到那个令人头疼的时刻——当模块间的信号连线从最初的几条膨胀到几十条,密密麻麻…...

AI 模型本地化部署

一、什么是 AI 模型本地化部署? 就是:把大模型 / AI 程序从云端服务器,搬到你自己的电脑、服务器、设备上运行。 特点: 不联网也能用数据不上传,隐私安全速度更快、无费用可完全自定义 常见用途: 本地…...

HMCL启动器跨平台架构深度解析:多系统兼容性实现与性能优化技术对比

HMCL启动器跨平台架构深度解析:多系统兼容性实现与性能优化技术对比 【免费下载链接】HMCL A Minecraft Launcher which is multi-functional, cross-platform and popular 项目地址: https://gitcode.com/gh_mirrors/hm/HMCL HMCL(Hello Minecra…...

GD32F103VET6替换STM32F103VET6实战:ADC+DMA读取内部温度传感器,从-400℃到正常值的排查全记录

GD32F103VET6替换STM32F103VET6实战:从ADC异常到LIN引脚干扰的深度排查 最近在将产品从STM32F103VET6迁移到GD32F103VET6时,遇到了一个令人困惑的问题:内部温度传感器读数异常,显示为-400℃左右的离谱数值。这个问题看似简单&…...

QKeyMapper终极指南:Windows平台全设备按键映射与虚拟手柄模拟的完全解决方案

QKeyMapper终极指南:Windows平台全设备按键映射与虚拟手柄模拟的完全解决方案 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper,Qt开发Win10&Win11可用,不修改注册表、不需重新启动系统,可立即生效和停止。支持游戏手柄…...

DeepSeek V4模型的Agent能力实测

DeepSeek V4 系列发布之后,关于它能不能用、好不好用的讨论很多,但大部分评测还停留在普通对话或编码上。CowAgent 作为一个开源中立的 Agent 框架,则更关心模型在 Agent 链路中的真实表现,包括任务规划、复杂编码、长期记忆、浏览…...

终极指南:3步实现Unity游戏实时翻译,打破语言障碍

终极指南:3步实现Unity游戏实时翻译,打破语言障碍 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator XUnity.AutoTranslator是一款专为Unity游戏设计的智能翻译插件,让你无…...

QueryExcel:如何在5分钟内从上百个Excel文件中找到你需要的数据?

QueryExcel:如何在5分钟内从上百个Excel文件中找到你需要的数据? 【免费下载链接】QueryExcel 多Excel文件内容查询工具。 项目地址: https://gitcode.com/gh_mirrors/qu/QueryExcel 在日常工作中,你是否曾经面对过这样的困境&#xf…...

Linux RT 调度器的 rt_mutex:实时互斥锁的优先级继承

简介在工业控制、自动驾驶、航天嵌入式、工控网关等硬实时场景中,Linux 原生普通互斥锁mutex存在致命短板:无法规避经典的优先级反转问题。低优先级任务持有锁阻塞中高优先级实时任务,高优先级任务又被普通分时任务抢占,系统实时响…...

从金融到政务:运维智能体行业落地实战与价值证明

最好的技术,一定能在真实场景中创造可量化价值。 Lerwee运维智能体已在金融、交通、制造、政务等行业规模化落地,服务 1000 客户,覆盖核心业务与关键基础设施。 本文选取四大标杆案例,还原真实痛点、架构设计、落地过程与价值成果…...

FigmaCN中文界面插件:3分钟免费实现Figma界面全中文化的终极指南

FigmaCN中文界面插件:3分钟免费实现Figma界面全中文化的终极指南 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 还在为Figma的英文界面而烦恼吗?专业术语看不懂…...

类脑计算融合物理机理,镜像视界实现孪生高效落地

类脑计算融合物理机理,镜像视界实现孪生高效落地——镜像视界新一代高效可信镜像孪生技术白皮书前言当前数字孪生与视频孪生行业,深陷落地成本高、建模周期长、算法不可信、规模化无望的深层困境,传统技术路线始终无法突破数据驱动黑盒、重型…...

3个步骤快速生成Beyond Compare 5密钥:完整授权激活终极方案

3个步骤快速生成Beyond Compare 5密钥:完整授权激活终极方案 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen 你是否正在寻找一个简单可靠的方法来解除Beyond Compare 5的30天试用限制…...

终极硬件调优指南:如何用Universal x86 Tuning Utility轻松解锁Intel/AMD设备性能

终极硬件调优指南:如何用Universal x86 Tuning Utility轻松解锁Intel/AMD设备性能 【免费下载链接】Universal-x86-Tuning-Utility Unlock the full potential of your Intel/AMD based device. 项目地址: https://gitcode.com/gh_mirrors/un/Universal-x86-Tunin…...

《龙虾OpenClaw系列:从嵌入式裸机到芯片级系统深度实战60课》032、Bootloader设计——从Flash加载到固件升级

OpenClaw系列032:Bootloader设计——从Flash加载到固件升级 一、一次现场升级失败的血泪史 去年冬天,某客户现场设备批量变砖。现象很统一:上电后LED狂闪三次,然后死寂。远程抓日志,发现Bootloader在CRC校验阶段直接跳到了错误处理——0x1FFF0000的复位向量被读成了全0x…...

2026届最火的五大降重复率工具实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 要降低AI生成文本的检测率,关键之处在于让内容展现出人类写作的典型特征&#xf…...

Python基础操作

基本操作方法 快捷键 ctrlK,ctrlC/U:注释以及解除注释 ctrl,:进入设置 ctrl~:打开命令行...

《龙虾OpenClaw系列:从嵌入式裸机到芯片级系统深度实战60课》031、设备树与硬件描述:从寄存器到设备模型的映射

031、设备树与硬件描述:从寄存器到设备模型的映射 一次让我熬夜到凌晨三点的设备树调试 去年做一款基于i.MX6ULL的工业控制器,外挂了一个SPI接口的ADC芯片——AD7689。硬件设计没问题,原理图确认了三遍,PCB打样回来焊接完,上电。结果呢?SPI读回来的数据全是0xFF。 我第…...

告别手动抢购!用Python+Selenium写一个淘宝/京东秒杀脚本(附完整代码和避坑指南)

PythonSelenium电商秒杀脚本实战:从环境搭建到精准执行的完整指南 每次电商大促时,手动抢购总让人手忙脚乱?作为Python开发者,我们可以用Selenium这个强大的浏览器自动化工具来提升效率。本文将带你从零开始构建一个合规、高效的…...

科技巨头隐私博弈:从商业模式到技术架构的十年演进

1. 从一篇旧文看科技巨头的“隐私游戏”:一场持续十余年的博弈2012年1月,Brian Bailey在EE Times上发表了一篇题为《What were they thinking: Google is at it again》的评论文章。这篇文章的核心,并非探讨某个具体的芯片设计工具或半导体工…...

AI赋能科研:构建模块化工作流,打造你的“第二大脑”

1. 项目概述:当AI成为科研的“第二大脑”如果你是一名科研工作者,无论是学生、研究员还是工程师,大概率都经历过这样的场景:面对海量的文献,感觉无从下手;处理复杂的实验数据,被重复性劳动消耗大…...

2023汽车网络安全报告:CVE激增150%,攻击影响扩大,生成式AI重塑攻防格局

1. 2023年汽车网络安全态势总览:一场永不停歇的攻防战干了十几年技术,从嵌入式到车联网,我越来越觉得,汽车行业现在最头疼的可能不是电池续航,也不是自动驾驶的算法,而是网络安全。这就像你给一辆车装上了最…...

影刀RPA如何实现店群自动化:详解拼多多与TEMU的“分身裂变”与全栈无人值守矩阵

大家好,我是林焱,一名专注电商底层架构设计与 RPA 自动化开发的独立开发者。 在电商圈摸爬滚打的这些年,我见证了无数店群卖家的起起落落。无论是死磕拼多多下沉市场的本土玩家,还是在 TEMU 跨境赛道上寻求增量的出海先锋&#x…...

栈数据结构详解:从入门到实战

一、栈是什么栈是后进先出 LIFO 的线性数据结构。只允许在一端进出(栈顶)另一端封闭(栈底)先进去的后出来,后进去的先出来生活例子:叠盘子、快递纸箱堆叠。二、栈核心操作固定五个基础操作:入栈…...