如何指示JAXB处理此事?
XML
<root>
<parent>
<child id="1" name="foo" />
</parent>
<parent>
<child id="3" name="foo2" />
</parent>
<parent>
<child id="4" name="bar2" />
</parent>
<parent>
<child id="2" name="bar" />
</parent>
</root>
Root.java
@XmlRootElement
public class Root {
@XmlElement(name="parent/child")
List<Child> allChildren;
}
这不起作用... allChildren为空。
答案 0 :(得分:13)
您可以更改模型并执行以下操作:
<强>根强>
@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public class Root {
@XmlElement(name="parent")
List<Parent> allParents;
}
<强>父强>
@XmlAccessorType(XmlAccessType.FIELD)
public class Parent {
@XmlElement(name="child")
List<Child> allChildren;
}
<强>更新强>
是否可以避免使用父类?
有几种不同的方法可以实现这一目标:
选项#1 - 使用XmlAdapter的任何JAXB实现
您可以使用XmlAdapter虚拟添加Parent
类。
<强> ChildAdapter 强>
import javax.xml.bind.annotation.adapters.XmlAdapter;
public class ChildAdapter extends XmlAdapter<ChildAdapter.Parent, Child> {
public static class Parent {
public Child child;
}
@Override
public Parent marshal(Child v) throws Exception {
Parent parent = new Parent();
parent.child = v;
return parent;
}
@Override
public Child unmarshal(Parent v) throws Exception {
return v.child;
}
}
<强>根强>
@XmlJavaTypeAdapter
注释用于引用XmlAdapter
。
import java.util.List;
import javax.xml.bind.annotation.*;
import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public class Root {
@XmlElement(name="parent")
@XmlJavaTypeAdapter(ChildAdapter.class)
List<Child> allChildren;
}
儿童强>
import javax.xml.bind.annotation.*;
@XmlAccessorType(XmlAccessType.FIELD)
public class Child {
@XmlAttribute
int id;
@XmlAttribute
String name;
}
选项#2 - 使用EclipseLink JAXB(MOXy)
如果您使用EclipseLink JAXB (MOXy)作为JAXB (JSR-222)实施,那么您可以执行以下操作(注意:我是MOXy主管):
<强>根强>
import java.util.List;
import javax.xml.bind.annotation.*;
@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public class Root {
@XmlElement(name="parent")
List<Child> allChildren;
}
儿童强>
MOXy的@XmlPath
注释与您在帖子中尝试使用@XmlElement
注释的方式非常相似。
import javax.xml.bind.annotation.*;
import org.eclipse.persistence.oxm.annotations.XmlPath;
@XmlAccessorType(XmlAccessType.FIELD)
public class Child {
@XmlPath("child/@id")
int id;
@XmlPath("child/@name")
String name;
}
了解更多信息
答案 1 :(得分:2)
您必须创建一个代表<parent>
元素的类,例如
@XmlAccessorType(XmlAccessType.FIELD)
public class Parent {
@XmlElement(name="child")
Child child;
}
然后您可以创建一个类型适配器
public class ParentToChildAdapter extends XmlAdapter<Parent, Child> {
public Parent marshal(Child c) {
Parent p = new Parent();
p.child = child;
return p;
}
public Child unmarshal(Parent p) {
return p.child;
}
}
并在根类
上使用它@XmlRootElement
public class Root {
@XmlElement(name="parent")
@XmlJavaTypeAdapter(ParentToChildAdapter.class)
List<Child> allChildren;
}
答案 2 :(得分:1)
您可以尝试使用XmlElementWrapper
注释,但我不确定它应该如何与多个包装器节点一起使用:
@XmlRootElement
public class Root {
@XmlElementWrapper(name="parent")
@XmlElement(name="child")
List<Child> allChildren;
}
答案 3 :(得分:0)
试试这个
@XmlRootElement
class Root {
List<Child> allChildren = new ArrayList<Child>();
private static class Parent {
@XmlElement
Child child;
}
@XmlElement
public void setParent(Parent p) {
allChildren.add(p.child);
}
}