溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Jackson對Java8時間類型的序列化跟反序列化的實現(xiàn)方法

發(fā)布時間:2021-06-29 16:27:31 來源:億速云 閱讀:571 作者:chen 欄目:大數(shù)據(jù)

這篇文章主要講解了“Jackson對Java8時間類型的序列化跟反序列化的實現(xiàn)方法”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Jackson對Java8時間類型的序列化跟反序列化的實現(xiàn)方法”吧!

Jackson對Java8時間類型的序列化跟反序列化

前言

默認的情況下,Jackson序列化/反序列化 Java8 新增的時間類型不會序列化成字符串或者時間戳,因為沒有相對應(yīng)的序列化策略,所以我們可以自己來配置對象的序列化跟反序列化策略,也可以引用jackson-datatype-jsr310的jar包來進行處理,下面我們以LocalDateTime作為示例

引入JSR310依賴

在項目內(nèi),我們引用下依賴

<dependency>
    <groupId>com.fasterxml.jackson.datatype</groupId>
    <artifactId>jackson-datatype-jsr310</artifactId>
    <version>2.8.11</version>
</dependency>

JSR310默認配置

默認的情況下,JSR310給我們提供了轉(zhuǎn)換成字符串的序列化/反序列化類,分別是LocalDateTimeSerializer/LocalDateTimeDeserializer,我們可以使用已經(jīng)有的實現(xiàn),來進行序列化

我們往Jackson的ObjectMapper內(nèi)注冊一個JSR310提供的JavaTimeModule模塊,JavaTimeModule內(nèi),我們需要配置LocalDateTime的的序列化策略,具體代碼如下

ObjectMapper objectMapper = new ObjectMapper();
JavaTimeModule javaTimeModule = new JavaTimeModule();
javaTimeModule.addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")))
              .addDeserializer(LocalDateTime.class,new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
              
objectMapper.registerModule(javaTimeModule);

自定義配置Java8時間類型的序列化/反序列化

這次,我們自定義轉(zhuǎn)換成秒級的時間戳,Jackson提供了JsonDeserializerJsonSerializer兩個抽象類,以上兩個分別是反序列化跟序列化的父類,我們繼承它并且實現(xiàn)抽象方法,具體代碼如下

public class InstantSerializer extends JsonSerializer<LocalDateTime> {

    @Override
    public void serialize(LocalDateTime value, JsonGenerator gen, SerializerProvider serializers) throws IOException, JsonProcessingException {
        gen.writeNumber(DateUtils.toSecond(value));
    }
}

public class InstantDeserializer extends JsonDeserializer<LocalDateTime> {

    @Override
    public LocalDateTime deserialize(JsonParser p, DeserializationContext txt) throws IOException, JsonProcessingException {
        return Instant.ofEpochSecond(p.getLongValue()).atZone(ZoneId.systemDefault()).toLocalDateTime();
    }
}

將定義的序列化規(guī)格,注冊到ObjectMapper里面去

ObjectMapper objectMapper = new ObjectMapper();
JavaTimeModule javaTimeModule = new JavaTimeModule();
javaTimeModule.addSerializer(LocalDateTime.class, new InstantSerializer())
              .addDeserializer(LocalDateTime.class,new InstantDeserializer());
              
objectMapper.registerModule(javaTimeModule);

總結(jié)

到此,我們大概介紹了兩種配置的方法,一種是jsr310已經(jīng)提供的,另外一種是通過繼承jackson提供的抽象類,自己進行實現(xiàn),兩者實現(xiàn)上差不多,不過通過繼承更靈活,更可控,使用jsr310更方便,具體的使用就仁者見仁智者見智了

感謝各位的閱讀,以上就是“Jackson對Java8時間類型的序列化跟反序列化的實現(xiàn)方法”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Jackson對Java8時間類型的序列化跟反序列化的實現(xiàn)方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI