我有以下两个课程:
public class MyChild
{
@JsonProperty
public int x;
}
public class MyTest
{
public void MyChild() {}
@JsonSerialize(using = MapValueSerializer.class)
private Map<String, MyChild> childs = new LinkedHashMap<>();
}
我希望孩子将其序列化为MyChild
的数组而不是映射(仅值)。因此,我使用以下自定义序列化程序:
public class MapValueSerializer extends StdSerializer<Map<String, ?>>
{
protected MapValueSerializer()
{
this(null);
}
protected MapValueSerializer(Class<Map<String, ?>> t)
{
super(t);
}
@Override
public void serialize(Map<String, ?> value, JsonGenerator gen, SerializerProvider provider) throws IOException
{
provider.defaultSerializeValue(value.values(), gen);
}
}
当我现在使用JsonSchemaGenerator
从MyTest
生成模式时,我得到以下信息:
{
"type" : "object",
"id" : "urn:jsonschema:com:myclasses:MyTest",
"properties" : {
"childs" : {
"type" : "any"
}
}
}
但是子级不应该是“任何”类型,而应该是“对象”类型。如果删除序列化程序,则类型为“对象”。我是否必须添加一些内容以使模式生成器知道该类型?
答案 0 :(得分:1)
在我用以下方法覆盖acceptJsonFormatVisitor()
类中的MapValueSerializer
后,它可以工作:
@Override
public void acceptJsonFormatVisitor(JsonFormatVisitorWrapper visitor, JavaType typeHint) throws JsonMappingException
{
JavaType valueType = ((MapType) typeHint).getContentType();
visitor.getProvider().findValueSerializer(valueType).acceptJsonFormatVisitor(visitor, valueType);
}
然后,子类型为“对象”,并且在架构中还会生成子元素“ x”。