解決ObjectMapper序列換Map時候的坑
ObjectMapper序列換Map時候的坑
今天,工作中,再一個分布式應(yīng)用中,一個服務(wù)要調(diào)用另外一個服務(wù),傳輸?shù)臄?shù)據(jù)時,返回的類型的Map<Integer,Integer>類型
的數(shù)據(jù),但是我打印日志發(fā)現(xiàn),數(shù)據(jù)是有數(shù)據(jù)的,但是通過key始終get不出來數(shù)據(jù),后來發(fā)現(xiàn)傳輸回來的數(shù)據(jù)的key變成了String, 是不是很詭異。
打印日志的代碼如下
打印的結(jié)果如下:
作為技術(shù)人,看到這樣的情況,就像刨根問底,然后的看到了項目中使用的源碼,然后本地模擬了下,發(fā)現(xiàn)原來
是ObjectMapper的序列化的問題
打印處理的是 null,22,說明key變成了String。
怎么解決這個問題,看下代碼:
很簡單只要轉(zhuǎn)化的時候講Object.class轉(zhuǎn)化成map.getClass();,就可以了,結(jié)果輸出的是 22,null
jackson ObjectMapper 序列化成json
屬性值為null時轉(zhuǎn)換為""空字符串
import java.io.IOException; import org.codehaus.jackson.JsonGenerationException; import org.codehaus.jackson.JsonGenerator; import org.codehaus.jackson.JsonProcessingException; import org.codehaus.jackson.map.JsonMappingException; import org.codehaus.jackson.map.JsonSerializer; import org.codehaus.jackson.map.ObjectMapper; import org.codehaus.jackson.map.SerializerProvider; import org.junit.Test; public class JsonTest { protected static String getJson(Object obj) { ObjectMapper mapper = new ObjectMapper(); // null替換為"" mapper.getSerializerProvider().setNullValueSerializer(new JsonSerializer<Object>() { @Override public void serialize(Object arg0, JsonGenerator arg1, SerializerProvider arg2) throws IOException, JsonProcessingException { arg1.writeString(""); } }); String str = null; try { str = mapper.writeValueAsString(obj); } catch (JsonGenerationException e) { e.printStackTrace(); } catch (JsonMappingException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return str; } @Test public void test() { System.out.println(getJson(new TestObject()));//TestObject必須是POJO對象 } } class TestObject { String name = "張三"; String sex = null; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } }
運(yùn)行結(jié)果:{"name":"張三","sex":""}
maven依賴
<dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency>
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot使用ApplicationEvent&Listener完成業(yè)務(wù)解耦
這篇文章主要介紹了SpringBoot使用ApplicationEvent&Listener完成業(yè)務(wù)解耦示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05一篇文章告訴你JAVA Mybatis框架的核心原理到底有多重要
yBatis的底層操作封裝了JDBC的API,MyBatis的工作原理以及核心流程與JDBC的使用步驟一脈相承,MyBatis的核心對象(SqlSession,Executor)與JDBC的核心對象(Connection,Statement)相互對應(yīng)2021-06-06springboot tomcat最大線程數(shù)與最大連接數(shù)解析
這篇文章主要介紹了springboot tomcat最大線程數(shù)與最大連接數(shù)解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06Mybatis-plus中QueryWrapper的多種用法小結(jié)
本文主要介紹了Mybatis-plus中QueryWrapper的多種用法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04SpringCloud微服務(wù)續(xù)約實現(xiàn)源碼分析詳解
這篇文章主要介紹了SpringCloud微服務(wù)續(xù)約實現(xiàn)源碼分析,服務(wù)續(xù)期和服務(wù)注冊非常相似,服務(wù)注冊在Eureka?Client程序啟動之后開啟,并同時開啟服務(wù)續(xù)期的定時任務(wù)2022-11-11