SpringBoot基于Jackson解決Long型長度丟失問題
問題背景
JavaScript能處理的數(shù)據(jù)精度有限,長度一旦超過17位就會發(fā)生長度丟失。因此,id值在被序列化為JSON時經(jīng)常會有后幾位與原數(shù)據(jù)匹配不上的問題。

數(shù)據(jù)庫中的數(shù)據(jù)

可以發(fā)現(xiàn)頁面拿到的數(shù)據(jù)的id值和數(shù)據(jù)庫中的id值最后兩位不一致
為了解決該問題,可以將Long型轉化為String
可利用jackson的ObjectMapper來實現(xiàn)
解決方法
ObjectMapper(對象轉換器),是jackson中的一個類,它實現(xiàn)了java對象到JSON之間的轉換(序列化、反序列化)。
當ObjectMapper中固有的序列化器(或反序列化器)不能滿足我們的需求時,我們需要自定義一個對象轉換器,即創(chuàng)建 ObjectMapper 的子類,為其添加新的序列化器,例如 (Long --> String) 的序列化器
實現(xiàn)步驟
1. 自定義對象轉換器,添加序列化器(或反序列化器)
2. 將該對象轉換器加入到 SpringMVC 的消息轉換器隊列中
自定義的對象轉換器即為ObjectMapper的子類,為其添加序列化器
/**
* 對象轉換器 ObjectMapper:基于jackson將Java對象轉為json(序列化),或者將json轉為Java對象(反序列化)
*
* ObjectMapper中固有的序列化器(或反序列化器)可能不能滿足我們的需求
* 因此需要創(chuàng)建 ObjectMapper 的子類,自定義新的序列化器,例如 Long --> String 的序列化器
*
*/
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() {
super();
//收到未知屬性時不報異常
this.configure(FAIL_ON_UNKNOWN_PROPERTIES, false);
//反序列化時,屬性不存在的兼容處理
this.getDeserializationConfig().withoutFeatures(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);
// SimpleModule對象,添加各種序列化器和反序列化器
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) // 實現(xiàn) Long --> String 的序列化器
.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)));
// 對自定義的 simpleModule 進行注冊
this.registerModule(simpleModule);
}
}
現(xiàn)在已經(jīng)創(chuàng)建出了自定義的對象轉換器,但還無法生效,需要對它進行相關配置
在WebMVC配置類中,重寫extendMessageConverters方法,將自定義的對象轉換器加入到消息轉換器隊列中,使其生效
/**
* 擴展 Spring MVC 的消息轉換器
*
* 將自定義的對象轉換器 JacksonObjectMapper 加入到 SpringMVC 的消息轉換器隊列中
*
* @param converters
*/
@Override
protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
log.info("擴展消息轉換器......");
MappingJackson2HttpMessageConverter messageConverter = new MappingJackson2HttpMessageConverter();
messageConverter.setObjectMapper(new JacksonObjectMapper());
converters.add(0, messageConverter);
}
再次測試結果如下

可以發(fā)現(xiàn)此時頁面拿到的id值都已經(jīng)變成了String,而且與數(shù)據(jù)庫中的id值完全一致
如此,便解決了Long型長度丟失問題
到此這篇關于SpringBoot基于Jackson解決Long型長度丟失問題的文章就介紹到這了,更多相關SpringBoot Long型長度丟失內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
kafka 重新分配partition和調(diào)整replica的數(shù)量實現(xiàn)
當需要提升Kafka集群的性能和負載均衡時,可通過kafka-reassign-partitions.sh命令手動重新分配Partition,增加節(jié)點后,可以將Topic的Partition的Leader節(jié)點均勻分布,以提高寫入和消費速度,感興趣的可以了解一下2022-03-03
Mybatis Plus 字段為空值時執(zhí)行更新方法未更新解決方案
這篇文章主要介紹了Mybatis Plus 字段為空值時執(zhí)行更新方法未更新解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-09-09
Spring?Cloud?Gateway?服務網(wǎng)關的部署與使用詳細講解
這篇文章主要介紹了Spring?Cloud?Gateway?服務網(wǎng)關的部署與使用詳細介紹,本文給大家講解的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
JAVA中的函數(shù)式接口Function和BiFunction詳解
這篇文章主要介紹了JAVA中的函數(shù)式接口Function和BiFunction詳解,JDK的函數(shù)式接口都加上了@FunctionalInterface注解進行標識,但是無論是否加上該注解只要接口中只有一個抽象方法,都是函數(shù)式接口,需要的朋友可以參考下2024-01-01
IDEA中SpringBoot項目的yml多環(huán)境配置方式
這篇文章主要介紹了IDEA中SpringBoot項目的yml多環(huán)境配置,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-10-10

