Jackson優(yōu)雅序列化Java枚舉類過程解析
1. 前言
在Java開發(fā)中我們?yōu)榱吮苊膺^多的魔法值,使用枚舉類來封裝一些靜態(tài)的狀態(tài)代碼。但是在將這些枚舉的意思正確而全面的返回給前端卻并不是那么順利,我們通常會使用Jackson類庫序列化對象為JSON,今天就來講一個關(guān)于使用Jackson序列化枚舉的通用性技巧。
2. 通用枚舉范式
為了便于統(tǒng)一處理和規(guī)范統(tǒng)一的風格,建議指定一個統(tǒng)一的抽象接口,例如:
/** * The interface Enumerator. */ public interface Enumerator { /** * Code integer. * * @return the integer */ Integer code(); /** * Description string. * * @return the string */ String description(); }
我們來寫一個實現(xiàn)來標識性別:
public enum GenderEnum implements Enumerator { UNKNOWN(0, "未知"), MALE(1, "男"), FEMALE(2, "女"); private final Integer code; private final String description; GenderEnum(Integer code, String description) { this.code = code; this.description = description; } @Override public Integer code() { return code; } @Override public String description() { return description; } }
3. 序列化枚舉
如果我們直接使用Jackson對枚舉進行序列化,將只能簡單的輸出枚舉的String名稱:
@Resource private ObjectMapper objectMapper; @Test void enumTest() { try { String s = objectMapper.writeValueAsString(GenderEnum.MALE); // 輸出字符串 MALE System.out.println(s); } catch (JsonProcessingException e) { e.printStackTrace(); } }
我們期望將GenderEnum.MALE 序列化為 {"code":1,"description":"男"} 。我們可以向ObjectMapper定制化一個Module來實現(xiàn)這種個性化需求:
// 聲明一個簡單Module 對象 SimpleModule module = new SimpleModule(); // 給Module 添加一個序列化器 module.addSerializer(Enumerator.class, new JsonSerializer<Enumerator>() { @Override public void serialize(Enumerator value, JsonGenerator gen, SerializerProvider serializers) throws IOException { // 開始寫入對象 gen.writeStartObject(); // 分別指定 k v code description gen.writeNumberField("code",value.code()); gen.writeStringField("description",value.description()); // 顯式結(jié)束操作 gen.writeEndObject(); } }); // 注冊 Module objectMapper.registerModule(module);
然后再次執(zhí)行就會獲取我們期望的結(jié)果。然而這并不算合理。
4. Spring Boot 中自動全局配置
在Spring Boot應(yīng)用中我們希望能全局配置。Spring Boot的自動配置為我們提供了一個個性化定制ObjectMapper的可能性,你只需要聲明一個Jackson2ObjectMapperBuilderCustomizer并注入Spring IoC:
@Bean public Jackson2ObjectMapperBuilderCustomizer enumCustomizer(){ return jacksonObjectMapperBuilder -> jacksonObjectMapperBuilder.serializerByType(Enumerator.class, new JsonSerializer<Enumerator>() { @Override public void serialize(Enumerator value, JsonGenerator gen, SerializerProvider serializers) throws IOException { gen.writeStartObject(); gen.writeNumberField("code",value.code()); gen.writeStringField("description",value.description()); gen.writeEndObject(); } }); }
這樣就實現(xiàn)了全局配置。
5. 總結(jié)
這里我們介紹了如何定制Jackson庫以達到對枚舉進行更加友好的序列化的目的。其實不單單枚舉,你也可以實現(xiàn)其它序列化,反序列化,時間輸出格式的定制。這些特性留給你自己挖掘。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java基礎(chǔ)理論Stream的Filter與謂詞邏輯
這篇文章主要為大家介紹了java基礎(chǔ)理論Stream的Filter與謂詞邏輯,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-03-03Python連接Java Socket服務(wù)端的實現(xiàn)方法
這篇文章主要介紹了Python連接Java Socket服務(wù)端的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01Java和MySQL數(shù)據(jù)庫中關(guān)于小數(shù)的保存問題詳析
在Java和MySQL中小數(shù)的精度可能會受到限制,如float類型的小數(shù)只能精確到6-7位,double類型也只能精確到15-16位,這篇文章主要給大家介紹了關(guān)于Java和MySQL數(shù)據(jù)庫中關(guān)于小數(shù)的保存問題,需要的朋友可以參考下2024-01-01IntelliJ IDEA之配置JDK的4種方式(小結(jié))
這篇文章主要介紹了IntelliJ IDEA之配置JDK的4種方式(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10SpringCloud中的Feign服務(wù)間的調(diào)用詳解
這篇文章主要介紹了SpringCloud中的Feign服務(wù)間的調(diào)用詳解,Feign 是一個聲明式的 REST 客戶端,它能讓 REST 調(diào)用更加簡單,Feign 供了 HTTP 請求的模板,通過編寫簡單的接口和插入注解,就可以定義好 HTTP 請求的參數(shù)、格式、地址等信息,需要的朋友可以參考下2024-01-01