问题是将两个类似的XML
映射到单个类结构:
xml1:<a1><b1 b1Value="xxxx1"/></a1>
xml2:<a2><b2 b2Value="xxxx2"/></a2>
由于遗留代码,我无法创建特殊的抽象公共类,因此我必须使用简单的继承:
1)类A1
及其子类A2
:
@XmlRootElement(name = "a1")
@XmlSeeAlso(A2.class)
public class A1 {
protected B1 b;
@XmlElement(name = "b1")
public B1 getB() { return b; }
public void setB(B1 b) { this.b = b; }
}
@XmlRootElement(name = "a2")
public class A2 extends A1 {
@XmlElement(name = "b2")
@Override
public B1 getB() { return super.getB(); }
@Override
public void setB(B1 b) { super.setB(b); }
}
2)班级B1
及其子类B2
:
@XmlSeeAlso(B2.class)
public class B1 {
protected String value;
@XmlAttribute(name = "b1Value")
public String getValue() { return value; }
public void setValue(String value) { this.value = value; }
}
public class B2 extends B1 {
@XmlAttribute(name = "b2Value")
@Override
public String getValue() { return super.getValue(); }
@Override
public void setValue(String value) { super.setValue(value); }
}
尝试解析xml2
时出现问题:
JAXBContext jc = JAXBContext.newInstance(A1.class);
Unmarshaller um = jc.createUnmarshaller();
A1 entity = (A1) um.unmarshal(new StringReader("<a2><b2 b2Value="xxxx2"/></a2>"));
在这种情况下,entity
对象成为类A2
的实例 - 它是正确的。但内部字段b
包含类B1
的实例,其内部value
为null
(见下图):
有什么想法吗?
答案 0 :(得分:0)
问题在于子类中的setter参数类型和返回类型的getter。
要解决此问题,有必要在B1
getter和setter中更改B2
到A2
。
因此,在A2
类中,它不应该是void setB(B1 b) { super.setB(b); }
,而是void setB(B2 b) { super.setB(b); }
,而不是B1 getB() { return super.getB(); }
,而应该是B2 getB() { return (B2)super.getB(); }
。