我有以下Java bean:
/**
* The top container. It uses generics.
*/
public class Response {
@JsonTypeInfo(
use = JsonTypeInfo.Id.NAME,
include = JsonTypeInfo.As.WRAPPER_OBJECT,
property = "type"
)
@JsonSubTypes({
@JsonSubTypes.Type(name = "AContent", value = A.class),
@JsonSubTypes.Type(name = "BContent", value = B.class),
})
private E object;
}
/**
* First type
*/
@JsonRootName("AContent")
public class A {
...
}
/**
* Second type
*/
@JsonRootName("BContent")
public class B {
...
}
处理请求时,我只希望得到以下输出:
{
AContent: { ...}
}
但是,我得到以下输出:
{
AContent: { ...}
}
元素" AContent"被包装到object元素中。我不想要一个通用的包装器对象。我也不想直接在通用对象中设置对象类型。
我想输出" AContent"直接在根元素内。
我们怎样才能与杰克逊实现这一目标?
提前感谢您的帮助。
致以最诚挚的问候,
黄鸭
答案 0 :(得分:1)
由于您说您可以为A和B提供基本实体,解决方案将是:
@JsonSerialize(using = ResponseSerializer.class)
public class Response<T> {
private T object;
...
}
基础实体(其他人必须扩展它):
@JsonTypeInfo(
use = JsonTypeInfo.Id.NAME,
include = JsonTypeInfo.As.WRAPPER_OBJECT
)
@JsonSubTypes({
@JsonSubTypes.Type(name = "AContent", value = EntityA.class),
@JsonSubTypes.Type(name = "BContent", value = EntityB.class),
})
public class Entity {
...
}
序列化器:
public class ResponseSerializer extends JsonSerializer<Response> {
@Override
public void serialize(Response value, JsonGenerator gen, SerializerProvider serializers) throws IOException, JsonProcessingException {
Class<?> responseClass = value.getObject().getClass();
JavaType responseJavaType = serializers.constructType(responseClass);
gen.writeStartObject();
gen.writeFieldName(serializers.findTypeSerializer(responseJavaType).getTypeIdResolver().idFromValue(value.getObject()));
serializers.findValueSerializer(responseClass).serialize(value.getObject(), gen, serializers);
/* Here you must manually serialize other properties */
/* Like gen.writeStringField("property", value.getProperty()); */
gen.writeEndObject();
}
}
P.S。我删除了你没有输出的额外注释。