在Jersey中,当使用Jackson进行JSON序列化时,不包括实现子类的额外属性。例如,给定以下类结构
@JsonTypeInfo(use=JsonTypeInfo.Id.NAME, include=JsonTypeInfo.As.PROPERTY, property="@class")
@JsonSubTypes({
@JsonSubTypes.Type(value = Foo.class, name = "foo")
}
public abstract class FooBase {
private String bar;
public String getBar() {
return bar;
}
public void setBar( String bar ) {
this.bar = bar;
}
}
public class Foo extends FooBase {
private String biz;
public String getBiz() {
return biz;
}
public void setBiz( String biz ) {
this.biz = biz;
}
}
以下泽西岛代码
@GET
public FooBase get() {
return new Foo();
}
我找回了以下json
{"@class" => "foo", "bar" => null}
但我真正想要的是
{"@class" => "foo", "bar" => null, "biz" => null}
另外,在我的web.xml中,我启用了POJOMappingFeature to solve this issue
<init-param>
<param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name>
<param-value>true</param-value>
</init-param>
编辑:修复了Java代码,使得setter设置正确,Foo不是抽象的
答案 0 :(得分:3)
它应该像你展示的那样工作;有一个可能的例外:如果启用JAXB注释(仅限),JAXB限制要求只使用getter / setter对来检测属性。 因此,尝试为'biz'添加setter,看看是否会改变它。
杰克逊注释不会发生这种情况;如果你把杰克逊和JAXB注释结合在一起(我认为泽西启用了两者),理想情况下并非如此。 如果还启用了Jackson注释处理,则在'getBiz'旁边添加@JsonProperty也应该可以解决问题。
最后,除非你需要JAXB注释,否则你只能恢复使用Jackson注释 - 在我看来,JAXB注释的主要用例是你需要生成XML和JSON,并使用JAXB(通过Jersey)对于XML。否则它们对JSON没用。
答案 1 :(得分:1)
使用POJOMappingFeature
您还可以使用JAXB注释您的类:
@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public abstract class FooBase {
private String bar;
}
@XmlType
@XmlAccessorType(XmlAccessType.FIELD)
public class Foo extends FooBase {
private String biz;
}