MessagePack Java Jackson 序列化和反序列化 POJO 爲 MessagePack 的數組類型用來與 msgpack-java:0.6 保持兼容性

在 msgpack-java 0.6 或者早期的版本中,POJO 在 MessagePack 中被序列化和反序列化爲數組變量。

變量的順序是基於 Java 類中變量的內部順序了,這種本來是一種原生的序列化方法,但是會導致一些問題。導致這些問題的原因是在 Java 對象的內部變量的順序與 Java 實現的順序不能保證完全的一致。

從另外一個角度來看,使用 jackson-databind 進行的序列化和反序列化方式是基於 POJO 的 Key-Value 對的。因此在 jackson-dataformat-msgpack 與 POJO 處理的方式是相同的。因此,這就導致了與 msgpack-java:0.6 或者早期的版本在對 POJO 進行序列化和反序列化的時候不兼容。

如果你希望在新的版本中也使用與 msgpack-java:0.6 或者早期版本相同的處理 POJO 的方法,你可以使用 JsonArrayFormat。具體使用方法如下所示:

ObjectMapper objectMapper = new ObjectMapper(new MessagePackFactory());
objectMapper.setAnnotationIntrospector(new JsonArrayFormat());

https://www.cwiki.us/display/Serialization/MessagePack+Jackson+Dataformat

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章