您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Java雪花算法生成的ID傳輸前端后精度丟失問題怎么解決”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Java雪花算法生成的ID傳輸前端后精度丟失問題怎么解決”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
在用雪花算法生成的ID傳輸到前端時,會出現后三位精度丟失
可以看到,我們得到的response為1594605819398193154
而前端展示的為1594605819398193200
這是因為JS是弱語言,前端接收數字類型參數為number
最大接收長度為16位,超出長度則會丟失精度
而JAVA的Long類型長度為19位,所以傳輸到前端的后三位精度丟失
所以我們解決該問題的思路就是:把java里的Long類型轉換為String返回給前端
可以把數據庫的ID字段從Long改為varchar,不過不建議這樣做,這樣修改后查詢無法走索引,降低了效率
我們可以在springmvc的配置類中(也就是繼承了WebMvcConfigurationSupport接口的那個配置類)重寫extendMessageConverters方法
/** * 擴展mvc框架的消息轉換器 * @param converters */ @SneakyThrows @Override protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) { //創建消息轉換器對象 MappingJackson2HttpMessageConverter messageConverter=new MappingJackson2HttpMessageConverter(); //設置對象轉換器,底層使用Jackson將Java對象轉為json messageConverter.setObjectMapper(new JacksonObjectMapper()); //將上面的消息轉換器對象追加到mvc框架的轉換器集合中 converters.add(0,messageConverter); }
編寫一個JacksonObjectMapper類
/** * 對象映射器:基于jackson將Java對象轉為json,或者將json轉為Java對象 * 將JSON解析為Java對象的過程稱為 [從JSON反序列化Java對象] * 從Java對象生成JSON的過程稱為 [序列化Java對象到JSON] */ public class JacksonObjectMapper extends ObjectMapper { public static final String DEFAULT_DATE_FORMAT = "yyyy-MM-dd"; public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss"; public static final String DEFAULT_TIME_FORMAT = "HH:mm:ss"; public JacksonObjectMapper() throws NoSuchFieldException { SimpleModule simpleModule = new SimpleModule() .addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT))) .addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT))) .addDeserializer(LocalTime.class, new LocalTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT))) .addSerializer(BigInteger.class, ToStringSerializer.instance) .addSerializer(Long.class, ToStringSerializer.instance) .addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT))) .addSerializer(LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT))) .addSerializer(LocalTime.class, new LocalTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT))); //注冊功能模塊 例如,可以添加自定義序列化器和反序列化器 this.registerModule(simpleModule); } }
注意:該方法是將所有Long類型都序列化成String的《全局轉換》
我這邊封裝了一個Result類,可以直接用String.valueOf去把Long類型的id轉換成String
也可以在Result類里多加一個判斷
讀到這里,這篇“Java雪花算法生成的ID傳輸前端后精度丟失問題怎么解決”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。