我正在尝试编写使用Jackson对对象进行序列化/反序列化的代码。
这些对象本质上是多态的:
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "name")
@JsonSubTypes({
@Type(value = ComparableQuery.class),
@Type(value = CompositeQuery.class)
})
public abstract class BaseQuery {
private final Long characteristicId;
...
}
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "name")
public class CompositeQuery extends BaseQuery {
private final String operator;
private final BaseQuery[] queries;
public CompositeQuery(Long characteristicId, Operator operator, BaseQuery... queries) {
super(characteristicId);
this.operator = operator.value;
this.queries = queries;
}
...
}
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "name")
@JsonSubTypes({
@Type(value = EqualQuery.class),
@Type(value = GreaterOrEqualQuery.class),
@Type(value = GreaterQuery.class),
@Type(value = LessOrEqualQuery.class),
@Type(value = LessQuery.class)
})
public abstract class ComparableQuery extends BaseQuery {
private final Object value;
private final String comparisonOperator;
...
}
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "name")
public class EqualQuery extends ComparableQuery {
public EqualQuery(Long characteristicId, Object value) {
super(characteristicId, value, "=");
}
}
我已经创建了一个集
Set<BaseQuery> queries = new HashSet<>();
BaseQuery megapixelCharacteristicQuery = new CompositeQuery(megapixelCharacteristic.getCharacteristicId(), CompositeQuery.Operator.AND, new GreaterOrEqualQuery(megapixelCharacteristic.getCharacteristicId(), 10), new LessOrEqualQuery(megapixelCharacteristic.getCharacteristicId(), 50));
queries.add(megapixelCharacteristicQuery);
现在,当我尝试序列化对象时,我收到以下JSON:
[
{
"characteristicId":391,
"operator":"AND",
"queries":[
{
"name":"GreaterOrEqualQuery",
"characteristicId":391,
"value":10,
"comparisonOperator":">="
},
{
"name":"LessOrEqualQuery",
"characteristicId":391,
"value":50,
"comparisonOperator":"<="
}
]
}
]
但当我尝试反序列化JSON文档时,我收到了以下异常:
com.fasterxml.jackson.databind.JsonMappingException: Unexpected token (END_OBJECT), expected FIELD_NAME: missing property 'name' that is to contain type id (for class com.example.decision.query.characteristic.BaseQuery)
at [Source: [{"characteristicId":391,"operator":"AND","queries":[{"name":"GreaterOrEqualQuery","characteristicId":391,"value":10,"comparisonOperator":">="},{"name":"LessOrEqualQuery","characteristicId":391,"value":50,"comparisonOperator":"<="}]}]; line: 1, column: 233] (through reference chain: java.util.HashSet[0])
at com.fasterxml.jackson.databind.JsonMappingException.from(JsonMappingException.java:261)
出于某种原因,JSON根对象中缺少
name
字段。
怎么修?
更新
它工作正常,当我尝试序列化只有例如
百万像素特征查询
对象:
BaseQuery megapixelCharacteristicQuery = new CompositeQuery(megapixelCharacteristic.getCharacteristicId(), CompositeQuery.Operator.AND, new GreaterOrEqualQuery(megapixelCharacteristic.getCharacteristicId(), 10), new LessOrEqualQuery(megapixelCharacteristic.getCharacteristicId(), 50));
在本例中,Jackson形成以下JSON(使用正确的
“名称”:“CompositeQuery”
):
{
"name":"CompositeQuery",
"characteristicId":391,
"operator":"AND",
"queries":[
{
"name":"GreaterOrEqualQuery",
"characteristicId":391,
"value":10,
"operator":">="
},
{
"name":"LessOrEqualQuery",
"characteristicId":391,
"value":50,
"operator":"<="
}
]
}
但是序列化/反序列化仍然不起作用,当
百万像素特性查询
放在HashSet中时
如何使它与HashSet一起工作?
此外,当我添加
defaultImpl=CompositeQuery时,即使使用
HashSet,它也可以正常工作。类
到JsonTypeInfo
注释,例如:
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "name", defaultImpl = CompositeQuery.class)
@JsonSubTypes({
@Type(value = ComparableQuery.class),
@Type(value = CompositeQuery.class)
})
public abstract class BaseQuery {
...
}
但这对我来说不是一个选项,因为我不知道在不同的情况下应该使用什么类型,所以我仍然在寻找一个解决方案,如何在我的JSON中正确地提供
name
参数。
最后,感谢以下问题中提供的答案,为什么Jackson多态序列化在列表中不起作用?我找到了一个解决方案:
Set<BaseQuery> queries = new HashSet<BaseQuery>() {
};
成功了。现在一切都按预期进行。
我的JSON字符串是: 我想要实现的是,当JSON中没有提供schemaVersion时,能够在默认情况下反序列化到SubClassV1,但即使在Superclass中将schemaVersion初始化为“1.0”时,我仍然会收到以下错误:
我正在尝试为接受JSON输入的前端库创建一个java SDK。本质上,此SDK将特定类型的对象转换为JSON,然后由前端库使用。 我正在使用杰克逊的多态序列化/反序列化使用它的注释系统。 我有一个基类a和扩展a的两个子类B和C。类a有一个类型字段,我用它来决定要使用哪个类(B或C)。语法如下所示: 现在,当我使用Jackson的ObjectMapper函数读取字符串化的JSON并转换为类A时,我根
假设我们有以下JSON, 在Java类中,我们有与上述JSON匹配的所有字段。 每次要反序列化的字段列表取决于发送信息的客户。 例如,对于customer 1,我们只想读回以下值,(并且跳过其他属性,即使在JSON中提供) 例如,对于客户2,我们希望读取以下值(并跳过其他属性,即使在JSON中提供) 使用Jackson反序列化JSON时,是否可以提供上面的数组,其中包括需要反序列化的字段, 更新:
问题内容: 是否可能:在类中有一个字段,而在Jackson库中进行序列化/反序列化时却为其使用不同的名称? 例如,我有“ Coordiantes”类。 对于从JSON反序列化,希望具有以下格式: 但是当我序列化对象时,结果应该是这样的: 我试图通过在getter和setter上都应用注释(具有不同的值)来实现此目的: 但我有一个例外: org.codehaus.jackson.map.exc.Un
我需要反序列化以下json: 将它的< code>id属性设置为< code>foo_id json属性。 我需要在自定义反序列化程序中执行此操作。实现这一点最简单的方法是什么? 我想以某种方式将json“转换”为 然后将此委托给杰克逊。 在本例中,对象的类型为Foo,但其他对象可能不属于此类。另外,在本例中,json是一个数字,但如果它也是一个字符串,我希望支持。所以,我需要一种通用的方法来做到
问题内容: 我正在使用JSON.NET对对象进行序列化以连接到REST API。我对象中需要序列化为JSON的属性之一具有动态属性名称。如果此属性的struct中包含的值是数字值,则JSON属性为“ type_id”,但是,如果此值是字符串值,则JSON属性名称为“ type_code”。我尝试为此使用自定义,但是在尝试序列化时收到以下消息: “状态为Property的令牌PropertyName