本文介紹了Jackson使用定制序列化程序和反序列化程序的對(duì)象映射器的處理方法,對(duì)大家解決問(wèn)題具有一定的參考價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧!
問(wèn)題描述
我有一個(gè)配置Jackson對(duì)象映射器的類。它為我的對(duì)象類型添加了一些定制的序列化程序和反序列化程序,如下所示:
public class JsonMapperFactory {
public static ObjectMapper createObjectMapper() {
final SimpleModule module = new SimpleModule("customerSerializationModule", new Version(1, 0, 0, "static version"));
addCustomDeserializersTo(module);
addCustomSerializersTo(module);
final ObjectMapper objectMapper = new ObjectMapper();
objectMapper.registerModule(module);
return objectMapper;
}
private static void addCustomSerializersTo(final SimpleModule module) {
module.addSerializer(DateTime.class, new DateTimeSerializer());
}
private static void addCustomDeserializersTo(final SimpleModule objectMapper) {
objectMapper.addDeserializer(DateTime.class, new DateTimeDeserializer());
}
}
我已經(jīng)在客戶自己的測(cè)試類中測(cè)試了我的客戶序列化程序,所以在測(cè)試這個(gè)JsonMapperFactory
類時(shí),我試圖簡(jiǎn)單地檢查所創(chuàng)建的對(duì)象映射器是否具有預(yù)期的序列化程序(或反序列化程序)這可以通過(guò)自省對(duì)象映射器來(lái)實(shí)現(xiàn),但它似乎沒有任何機(jī)制來(lái)實(shí)現(xiàn)這一點(diǎn)。
有人知道測(cè)試它的好方法嗎?
對(duì)于反序列化程序,我有以下幾點(diǎn):
private void assertThatObjectMapperUsesCorrectDeserializer(final Class<?> typeClazz, final Class<?> deserializerClazz) throws JsonMappingException {
final DeserializationConfig deserializationConfig = this.objectMapper.getDeserializationConfig();
final JsonDeserializer<Object> deserializer = this.objectMapper.getDeserializerProvider().findTypedValueDeserializer(deserializationConfig, javaTypeFor(typeClazz), null);
assertThat(deserializer, is(instanceOf(deserializerClazz)));
}
private JavaType javaTypeFor(final Class<?> clazz) {
return TypeFactory.type(clazz); //deprecated method :(
}
,它非常冗長(zhǎng),并且使用過(guò)時(shí)的方法。
我還沒有找到為序列化程序執(zhí)行類似測(cè)試的方法。因此,我目前已求助于序列化對(duì)象并檢查其序列化是否正確(實(shí)質(zhì)上復(fù)制了序列化程序測(cè)試)
歡迎您提出任何想法。
推薦答案
根據(jù)這里提供的答案和注釋,我最近重新設(shè)計(jì)了類,以便同時(shí)使用Module
和ObjectMapper
的構(gòu)建器。這使我能夠提供模擬并檢查是否向模塊添加了正確的(反)序列化程序,然后如預(yù)期的那樣將模塊注冊(cè)到對(duì)象映射器。
對(duì)象映射器生成器:
public class ObjectMapperBuilder {
ObjectMapper mapper;
public ObjectMapperBuilder configure(final ObjectMapper mapper) {
this.mapper = mapper;
return this;
}
public ObjectMapperBuilder withModule(final Module module) {
this.mapper.registerModule(module);
return this;
}
public ObjectMapper build() {
return this.mapper;
}
}
模塊生成器:
public class SimpleModuleBuilder {
SimpleModule module;
public SimpleModuleBuilder configure(final SimpleModule module) {
this.module = module;
return this;
}
public <X> SimpleModuleBuilder withSerializer(final Class<X> clazz, final JsonSerializer<X> serializer) {
this.module.addSerializer(clazz, serializer);
return this;
}
public <X> SimpleModuleBuilder withDeserializer(final Class<X> clazz, final JsonDeserializer<X> deserializer) {
this.module.addDeserializer(clazz, deserializer);
return this;
}
public SimpleModule build() {
return this.module;
}
}
最后,新的JsonMapperFactory:
public class JsonMapperFactory {
public static ObjectMapper configureObjectMapper(final ObjectMapper mapper, final SimpleModule module) {
final SimpleModuleBuilder modulebuilder = new SimpleModuleBuilder();
final SimpleModule configuredModule = modulebuilder.configure(module)
.withSerializer(DateTime.class, new DateTimeSerializer())
.withDeserializer(DateTime.class, new DateTimeDeserializer())
.build();
final ObjectMapperBuilder objectMapperBuilder = new ObjectMapperBuilder();
return objectMapperBuilder.configure(mapper).withModule(configuredModule).build();
}
}
工廠方法仍在Spring配置中使用,但配置現(xiàn)在實(shí)例化空白Module
和ObjectMapper
,然后將它們提供給隨后配置它們的工廠方法。
這篇關(guān)于Jackson使用定制序列化程序和反序列化程序的對(duì)象映射器的文章就介紹到這了,希望我們推薦的答案對(duì)大家有所幫助,