您好,登錄后才能下訂單哦!
這篇文章主要講解了“Jackson對Java8時間類型的序列化跟反序列化的實現方法”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Jackson對Java8時間類型的序列化跟反序列化的實現方法”吧!
默認的情況下,Jackson序列化/反序列化 Java8 新增的時間類型不會序列化成字符串或者時間戳,因為沒有相對應的序列化策略,所以我們可以自己來配置對象的序列化跟反序列化策略,也可以引用jackson-datatype-jsr310的jar包來進行處理,下面我們以LocalDateTime作為示例
在項目內,我們引用下依賴
<dependency> <groupId>com.fasterxml.jackson.datatype</groupId> <artifactId>jackson-datatype-jsr310</artifactId> <version>2.8.11</version> </dependency>
默認的情況下,JSR310給我們提供了轉換成字符串的序列化/反序列化類,分別是LocalDateTimeSerializer
/LocalDateTimeDeserializer
,我們可以使用已經有的實現,來進行序列化
我們往Jackson的ObjectMapper內注冊一個JSR310提供的JavaTimeModule模塊,JavaTimeModule內,我們需要配置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);
這次,我們自定義轉換成秒級的時間戳,Jackson提供了JsonDeserializer跟JsonSerializer兩個抽象類,以上兩個分別是反序列化跟序列化的父類,我們繼承它并且實現抽象方法,具體代碼如下
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(); } }
將定義的序列化規格,注冊到ObjectMapper里面去
ObjectMapper objectMapper = new ObjectMapper(); JavaTimeModule javaTimeModule = new JavaTimeModule(); javaTimeModule.addSerializer(LocalDateTime.class, new InstantSerializer()) .addDeserializer(LocalDateTime.class,new InstantDeserializer()); objectMapper.registerModule(javaTimeModule);
到此,我們大概介紹了兩種配置的方法,一種是jsr310已經提供的,另外一種是通過繼承jackson提供的抽象類,自己進行實現,兩者實現上差不多,不過通過繼承更靈活,更可控,使用jsr310更方便,具體的使用就仁者見仁智者見智了
感謝各位的閱讀,以上就是“Jackson對Java8時間類型的序列化跟反序列化的實現方法”的內容了,經過本文的學習后,相信大家對Jackson對Java8時間類型的序列化跟反序列化的實現方法這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。