亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js精度丟失解決方案(響應(yīng)和預(yù)覽數(shù)據(jù)不一致)

 更新時間:2025年06月04日 10:30:38   作者:汪了吧  
Java后端使用雪花算法生成的長ID在前端顯示時因JavaScript數(shù)字精度限制(最大安全整數(shù)為2^53)導(dǎo)致最后兩位丟失,這篇文章主要介紹了關(guān)于js精度丟失解決方案的相關(guān)資料,需要的朋友可以參考下

背景

后端使用雪花算法生成的id,在接口文檔測試中,響應(yīng)體中正常顯示。

在后續(xù)測試中,卻出現(xiàn)通過id查不到數(shù)據(jù)的情況,通過打開瀏覽器控制臺(F12)發(fā)現(xiàn),響應(yīng)和預(yù)覽中的數(shù)據(jù)不一致。

從下面圖片可以看出,響應(yīng)中JSON格式的數(shù)據(jù)是正常的,但是在預(yù)覽中卻出現(xiàn)跟原id不一致的情況,且通過分析發(fā)現(xiàn)只有最后兩位不一致,這里明顯出現(xiàn)了精度丟失

這里的id是正常的

在這里出現(xiàn)了精度丟失

問題分析

1. JavaScript 的數(shù)字精度限制

JavaScript 使用 IEEE 754 雙精度浮點(diǎn)數(shù)格式表示所有數(shù)字,這意味著:

  • 它能準(zhǔn)確表示的整數(shù)范圍是 -2^53 + 1 到 2^53 - 1(即 -9007199254740991 到 9007199254740991
  • 你的 ID 1922304585509261314 已經(jīng)超過了這個范圍(2^53 = 9007199254740992

2. 當(dāng)數(shù)字超過安全整數(shù)范圍時

超出 Number.MAX_SAFE_INTEGER(即 2^53 - 1)的數(shù)字會出現(xiàn)精度丟失(前端測試):

const bigId = 1922304585509261314;
console.log(bigId); // 輸出 1922304585509261300

為什么預(yù)覽顯示不正確?

開發(fā)工具(如瀏覽器控制臺、Postman等)在顯示 JSON 響應(yīng)時,會自動將數(shù)字類型的值轉(zhuǎn)換為 JavaScript 數(shù)字,從而導(dǎo)致精度丟失。實(shí)際響應(yīng)數(shù)據(jù)可能是正確的,但顯示時被轉(zhuǎn)換了。

解決方案

后端解決方案:

代碼

SpringBoot中可以通過編寫JsonConfig處理json精度丟失的配置,將Long類型轉(zhuǎn)化為String類型

@JsonComponent
public class JsonConfig {

    /**
     * 添加 Long 轉(zhuǎn) json 精度丟失的配置
     */
    @Bean
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        SimpleModule module = new SimpleModule();
        module.addSerializer(Long.class, ToStringSerializer.instance);
        module.addSerializer(Long.TYPE, ToStringSerializer.instance);
        objectMapper.registerModule(module);
        return objectMapper;
    }
}

代碼解釋

1. @JsonComponent 注解

  • 這個注解是 Spring Boot 提供的,用于標(biāo)記一個類作為 Jackson 的序列化/反序列化組件。
  • 被標(biāo)記的類會自動注冊到 Spring 的 Jackson ObjectMapper 中,全局生效。

2. JsonConfig 類

public class JsonConfig {
  • 這是一個配置類,專門用于自定義 Jackson 的 JSON 序列化行為。

3. jacksonObjectMapper 方法

@Bean
public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
  • @Bean 表示這個方法會返回一個由 Spring 管理的 Bean(這里是 ObjectMapper)。
  • Jackson2ObjectMapperBuilder 是 Spring Boot 提供的工具類,用于方便地配置 ObjectMapper。

4. 創(chuàng)建和配置 ObjectMapper

ObjectMapper objectMapper = builder.createXmlMapper(false).build();
  • 通過 builder 創(chuàng)建一個新的 ObjectMapper 實(shí)例,并禁用 XML 映射功能(createXmlMapper(false))。

5. 注冊自定義序列化模塊

SimpleModule module = new SimpleModule();
module.addSerializer(Long.class, ToStringSerializer.instance);
module.addSerializer(Long.TYPE, ToStringSerializer.instance);
objectMapper.registerModule(module);
  • SimpleModule:是 Jackson 提供的模塊,用于自定義序列化/反序列化規(guī)則。
  • module.addSerializer
    • Long.class:針對包裝類型的 Long
    • Long.TYPE:針對基本類型的 long。
    • ToStringSerializer.instance:將 Long 值直接轉(zhuǎn)換為字符串(而不是數(shù)字),避免精度丟失。
  • objectMapper.registerModule(module):將配置好的模塊注冊到 ObjectMapper。

6. 返回配置好的 ObjectMapper

return objectMapper;
  • 最終返回定制化的 ObjectMapper,Spring 會用它來處理所有 JSON 序列化/反序列化。

修改后測試

id已經(jīng)轉(zhuǎn)為字符串,顯示正常,無精度丟失

總結(jié)

  • JavaScript 的 Number 類型無法安全表示超過 53 位的整數(shù)(2^53),而 Java 的 Long 是 64 位。
  • 如果直接將 Long 作為數(shù)字序列化到 JSON,前端 JavaScript 解析時可能會丟失精度(例如 1234567890123456789 可能變成 1234567890123456800)。
  • 解決方案:將 Long 序列化為字符串(如 "1234567890123456789"),前端可以通過字符串解析避免精度問題。

到此這篇關(guān)于js精度丟失解決方案的文章就介紹到這了,更多相關(guān)js精度丟失解決內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 利用js判斷手機(jī)是否安裝某個app的多種方案

    利用js判斷手機(jī)是否安裝某個app的多種方案

    這篇文章主要介紹了利用js檢測手機(jī)是否安裝某個app的多種方案,當(dāng)判斷后如果安裝了直接打開,如果有沒有安裝將自動跳轉(zhuǎn)到下載的界面,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • JS解決IOS中拍照圖片預(yù)覽旋轉(zhuǎn)90度BUG的問題

    JS解決IOS中拍照圖片預(yù)覽旋轉(zhuǎn)90度BUG的問題

    下面小編就為大家?guī)硪黄狫S解決IOS中拍照圖片預(yù)覽旋轉(zhuǎn)90度BUG的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • javascript實(shí)現(xiàn)下雨效果

    javascript實(shí)現(xiàn)下雨效果

    本文主要介紹了javascript實(shí)現(xiàn)下雨效果的示例代碼。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • 理運(yùn)用命名空間讓js不產(chǎn)生沖突避免全局變量的泛濫

    理運(yùn)用命名空間讓js不產(chǎn)生沖突避免全局變量的泛濫

    為了避免變量之間的覆蓋與沖突,可以生成命名空間,命名空間是一種特殊的前綴,在不同的匿名函數(shù)中,根據(jù)功能聲明一個不同的命名空間
    2014-06-06
  • 利用HTML與JavaScript實(shí)現(xiàn)注冊頁面源碼

    利用HTML與JavaScript實(shí)現(xiàn)注冊頁面源碼

    這篇文章主要給大家介紹了關(guān)于利用HTML與JavaScript實(shí)現(xiàn)注冊頁面的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),對大家實(shí)現(xiàn)注冊頁面具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12
  • javascript Demo模態(tài)窗口

    javascript Demo模態(tài)窗口

    不多介紹了,應(yīng)該見很多了,見過很多網(wǎng)站用的是Jquery的插件,個人覺得不夠靈活。
    2009-12-12
  • 使用Javascript寫的2048小游戲

    使用Javascript寫的2048小游戲

    這篇文章主要介紹了使用Javascript寫的2048小游戲的相關(guān)資料,需要的朋友可以參考下
    2015-11-11
  • 原生js+canvas實(shí)現(xiàn)驗(yàn)證碼

    原生js+canvas實(shí)現(xiàn)驗(yàn)證碼

    這篇文章主要為大家詳細(xì)介紹了原生js+canvas實(shí)現(xiàn)驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • 微信小程序?qū)崿F(xiàn)拉鏈?zhǔn)降幕瑒域?yàn)證

    微信小程序?qū)崿F(xiàn)拉鏈?zhǔn)降幕瑒域?yàn)證

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)拉鏈?zhǔn)降幕瑒域?yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • JavaScript 中的 this 簡單規(guī)則

    JavaScript 中的 this 簡單規(guī)則

    想要確定this里規(guī)則是什么,其實(shí)方法很簡單,通過檢查它的調(diào)用位置,在函數(shù)被調(diào)用的時候確定this,下面就跟隨腳本之家小編一起通過本文學(xué)習(xí)吧
    2017-09-09

最新評論