作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在 Jackson 中的自定义反序列化器有问题。我想访问默认的序列化程序来填充我要反序列化的对象。在填充之后我会做一些自定义的事情,但首先我想用默认的 Jackson 行为反序列化对象。
这是我目前拥有的代码。
public class UserEventDeserializer extends StdDeserializer<User> {
private static final long serialVersionUID = 7923585097068641765L;
public UserEventDeserializer() {
super(User.class);
}
@Override
@Transactional
public User deserialize(JsonParser jp, DeserializationContext ctxt)
throws IOException, JsonProcessingException {
ObjectCodec oc = jp.getCodec();
JsonNode node = oc.readTree(jp);
User deserializedUser = null;
deserializedUser = super.deserialize(jp, ctxt, new User());
// The previous line generates an exception java.lang.UnsupportedOperationException
// Because there is no implementation of the deserializer.
// I want a way to access the default spring deserializer for my User class.
// How can I do that?
//Special logic
return deserializedUser;
}
}
我需要的是一种初始化默认反序列化器的方法,以便我可以在开始我的特殊逻辑之前预填充我的 POJO。
当从自定义反序列化器中调用反序列化时,无论我如何构造序列化器类,该方法似乎都是从当前上下文中调用的。由于我的 POJO 中的注释。由于显而易见的原因,这会导致堆栈溢出异常。
我已经尝试初始化一个BeanDeserializer
,但这个过程非常复杂,我还没有设法找到正确的方法来做到这一点。我也曾尝试过重载 AnnotationIntrospector
但无济于事,我认为这可能会帮助我忽略 DeserializerContext
中的注释。最后它接缝我可能已经使用 JsonDeserializerBuilders
取得了一些成功,尽管这需要我做一些神奇的事情来从 Spring 获取应用程序上下文。我将不胜感激任何可以引导我找到更清晰解决方案的事情,例如如何在不阅读 JsonDeserializer
注释的情况下构建反序列化上下文。
最佳答案
正如 StaxMan 已经建议的那样,您可以通过编写 BeanDeserializerModifier
并通过 SimpleModule
注册它来做到这一点。以下示例应该有效:
public class UserEventDeserializer extends StdDeserializer<User> implements ResolvableDeserializer
{
private static final long serialVersionUID = 7923585097068641765L;
private final JsonDeserializer<?> defaultDeserializer;
public UserEventDeserializer(JsonDeserializer<?> defaultDeserializer)
{
super(User.class);
this.defaultDeserializer = defaultDeserializer;
}
@Override public User deserialize(JsonParser jp, DeserializationContext ctxt)
throws IOException, JsonProcessingException
{
User deserializedUser = (User) defaultDeserializer.deserialize(jp, ctxt);
// Special logic
return deserializedUser;
}
// for some reason you have to implement ResolvableDeserializer when modifying BeanDeserializer
// otherwise deserializing throws JsonMappingException??
@Override public void resolve(DeserializationContext ctxt) throws JsonMappingException
{
((ResolvableDeserializer) defaultDeserializer).resolve(ctxt);
}
public static void main(String[] args) throws JsonParseException, JsonMappingException, IOException
{
SimpleModule module = new SimpleModule();
module.setDeserializerModifier(new BeanDeserializerModifier()
{
@Override public JsonDeserializer<?> modifyDeserializer(DeserializationConfig config, BeanDescription beanDesc, JsonDeserializer<?> deserializer)
{
if (beanDesc.getBeanClass() == User.class)
return new UserEventDeserializer(deserializer);
return deserializer;
}
});
ObjectMapper mapper = new ObjectMapper();
mapper.registerModule(module);
User user = mapper.readValue(new File("test.json"), User.class);
}
}
关于java - 如何从 Jackson 中的自定义解串器调用默认解串器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50388744/
我是一名优秀的程序员,十分优秀!