我的问题是关于我想使用同一个类来反序列化和重新序列化两个不同的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方法的上方是OS_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的0和false
“OS-FLV禁用:禁用”.所以我把注释
@JsonSerialize(include=JsonSerialize.Inclusion.NON_DEFAULT)
就在Flavor类之上.这有效但问题是,当我收到JSON A,其中“ram”和“OS-FLV-DISABLED:disabled”具有值0和false(可能的情况)时,上面提到的过程的结果是JSON B,因为这些两个字段被忽略.
所以确定这不是我的问题的解决方案,我读到有些人建议使用@JsonView或@JsonFilter,但我不明白如何在这种情况下应用这些Jackson功能.
我希望我很清楚,并提前感谢你的帮助.
最佳答案 您可以尝试的一件事是将ram和OS_FLV_DISABLED_disabled分别设置为Integer和Boolean类型.这样,如果这两个属性的json中没有值,那么它们将为null.并使用此注释@JsonInclude(Include.NON_NULL)来避免序列化null属性.