使用 jackson 将自定义反序列化 class 添加到已经存在的 @JsonDeserialize 注释中
Adding Custom deserialization class to already exsisting @JsonDeserialize annotation using jackson
我正在尝试通过编写自定义反序列化程序来反序列化 json。
这是我的代码。
public class EventLoginDeserializer extends StdDeserializer<EventLogin> {
public EventLoginDeserializer() {
this(null);
}
public EventLoginDeserializer(Class<EventLogin> event) {
super(event);
}
@Override
public EventLogin deserialize(JsonParser jsonParser, DeserializationContext deserializationContext)
throws IOException, JsonProcessingException {
JsonNode jsonNode = jsonParser.getCodec().readTree(jsonParser);
return EventLogin.builder().displayName(jsonNode.get("display_name"))
.timestamp(DateTime.now()).build();
}
@Override
public Class<EventLogin> handledType() {
return EventLogin.class;
}
}
这是我的主要片段 class。
ObjectMapper mapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
SimpleModule module = new SimpleModule();
module.addDeserializer(EventLogin.class, new EventLoginDeserializer());
mapper.registerModule(module);
String json = "{\"display_name\": \"Test Deserialization\", \"user_name\": \"test\"}";
EventLogin eventLogin = mapper.readValue(json, EventLogin.class);
System.out.println("readValue :::: " + eventLogin);
我有一个要求,我必须在 jar 文件中使用一个已经存在的 @JsonDeserialize
注释模型 class 并在上面添加一个反序列化 class。我的意思是这里与源文件中已经存在的 class 相同。
@AutoValue
@JsonDeserialize(builder = AutoValue_EventLogin.Builder.class)
@JsonInclude(JsonInclude.Include.NON_NULL)
public abstract class EventLogin
{
public abstract String displayName();
public abstract DateTime timestamp();
@AutoValue.Builder
public abstract static class Builder implements Login.Builder<Builder> {
public abstract Builder displayName(String displayName);
public abstract Builder emailId(DateTime timestamp);
public abstract EventLogin build();
}
}
问题是因为@JsonDeserialize
已经存在于jar文件中,所以根本没有考虑添加自定义反序列化器。意思是,自定义反序列化器 class 的重写反序列化方法未被执行。
那么如何克服这个问题呢?
去解决。 Jackson 让我们用 mixins 覆盖那些属性指定的值,这样我们就可以创建一个 mixin class 并添加到对象映射器中。
@JsonDeserialize(using = EventLoginDeserializer.class)
public static class EventLoginMixIn{}
然后在我们的主要 class
ObjectMapper mapperWithMixin = new ObjectMapper()
.addMixIn(EventLogin.class, EventLoginMixIn.class);
// Deserialize the eventlogin
EventLogin eventLogin = mapperWithMixin.readValue(actualJson, EventLogin.class);
我正在尝试通过编写自定义反序列化程序来反序列化 json。 这是我的代码。
public class EventLoginDeserializer extends StdDeserializer<EventLogin> {
public EventLoginDeserializer() {
this(null);
}
public EventLoginDeserializer(Class<EventLogin> event) {
super(event);
}
@Override
public EventLogin deserialize(JsonParser jsonParser, DeserializationContext deserializationContext)
throws IOException, JsonProcessingException {
JsonNode jsonNode = jsonParser.getCodec().readTree(jsonParser);
return EventLogin.builder().displayName(jsonNode.get("display_name"))
.timestamp(DateTime.now()).build();
}
@Override
public Class<EventLogin> handledType() {
return EventLogin.class;
}
}
这是我的主要片段 class。
ObjectMapper mapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
SimpleModule module = new SimpleModule();
module.addDeserializer(EventLogin.class, new EventLoginDeserializer());
mapper.registerModule(module);
String json = "{\"display_name\": \"Test Deserialization\", \"user_name\": \"test\"}";
EventLogin eventLogin = mapper.readValue(json, EventLogin.class);
System.out.println("readValue :::: " + eventLogin);
我有一个要求,我必须在 jar 文件中使用一个已经存在的 @JsonDeserialize
注释模型 class 并在上面添加一个反序列化 class。我的意思是这里与源文件中已经存在的 class 相同。
@AutoValue
@JsonDeserialize(builder = AutoValue_EventLogin.Builder.class)
@JsonInclude(JsonInclude.Include.NON_NULL)
public abstract class EventLogin
{
public abstract String displayName();
public abstract DateTime timestamp();
@AutoValue.Builder
public abstract static class Builder implements Login.Builder<Builder> {
public abstract Builder displayName(String displayName);
public abstract Builder emailId(DateTime timestamp);
public abstract EventLogin build();
}
}
问题是因为@JsonDeserialize
已经存在于jar文件中,所以根本没有考虑添加自定义反序列化器。意思是,自定义反序列化器 class 的重写反序列化方法未被执行。
那么如何克服这个问题呢?
去解决。 Jackson 让我们用 mixins 覆盖那些属性指定的值,这样我们就可以创建一个 mixin class 并添加到对象映射器中。
@JsonDeserialize(using = EventLoginDeserializer.class)
public static class EventLoginMixIn{}
然后在我们的主要 class
ObjectMapper mapperWithMixin = new ObjectMapper()
.addMixIn(EventLogin.class, EventLoginMixIn.class);
// Deserialize the eventlogin
EventLogin eventLogin = mapperWithMixin.readValue(actualJson, EventLogin.class);