我的问题是关于我想使用同一个类来反序列化和重新序列化两个不同的Jsons的事实。我试着更好地解释一下。 我有这些Jsons:
//JSON A
{
"flavors": [
{
"id": "52415800-8b69-11e0-9b19-734f1195ff37",
"name": "256 MB Server",
"ram": 256,
"OS-FLV-DISABLED:disabled":true
"links": [
{
"rel": "self",
"href": "http://www.myexample.com"
},
{
"rel": "bookmark",
"href":"http://www.myexample.com"
}
]
},
...
}
//JSON B
{
"flavors": [
{
"id": "52415800-8b69-11e0-9b19-734f1195ff37",
"name": "256 MB Server",
"links": [
{
"rel": "self",
"href": "http://www.myexample.com"
},
{
"rel": "bookmark",
"href":"http://www.myexample.com"
}
]
},
...
}
正如您所看到的,JSON B具有JSON A的所有字段,除了“ram”和 “OS-FLV禁用:禁用”。我使用的课程如下:
public class Flavor {
private String name;
private List<Link> links;
private int ram;
private boolean OS_FLV_DISABLED_disabled;
//constructor and getter/setter
}
@XmlRootElement
public class GetFlavorsResponse {
private List<Flavor> flavors;
//constructor and getter/setter
}
此外,在getter方法 isOS_FLV_DISABLED_disabled 上方,我已经添加了注释@XmlElement(name = "OS-FLV-DISABLED:disabled")
否则杰克逊不承认这个属性。
以下是情况的计划:
当我收到JSON A时没有问题,JSON结果再次是JSON A;但是当我收到JSON B时,进程反序列化 - 序列化的结果是:
//JSON C
{
"flavors": [
{
"id": "52415800-8b69-11e0-9b19-734f1195ff37",
"name": "256 MB Server",
"ram": 0,
"OS-FLV-DISABLED:disabled":false
"links": [
{
"rel": "self",
"href": "http://www.myexample.com"
},
{
"rel": "bookmark",
"href":"http://www.myexample.com"
}
]
},
...
}
现在我认为杰克逊设置的类属性不是Json中的第一件事 它们的默认值,分别是“ram”和 0 和 false “OS-FLV禁用:禁用”。所以我把注释
@JsonSerialize(include=JsonSerialize.Inclusion.NON_DEFAULT)
就在Flavor类之上。这有效,但问题是,当我收到JSON A,其中“ram”和“OS-FLV-DISABLED:disabled”具有值 0 和 false (可能的情况) ),上面提到的过程的结果是JSON B,因为忽略了这两个字段。 确定这不是我的问题的解决方案,我读到有些人建议使用 @JsonView 或 @JsonFilter ,但我不明白如何应用这些杰克逊这种情况下的功能。 我希望我很清楚,并提前感谢你的帮助。
答案 0 :(得分:2)
您可以尝试的一件事是将ram
和OS_FLV_DISABLED_disabled
分别设为Integer
和Boolean
类型。这样,如果这两个属性的json中没有值,那么它们将为null。并使用此批注@JsonInclude(Include.NON_NULL)
来避免序列化null属性。