我正在尝试将POJO映射到xml。现在POJO包含一些基本的String / Integer等属性,还有一些属于其他POJO类。我试图创建的xml映射文件,我希望在顶层的xml元素填充2级深度的java属性。
例如,如果我有2个java类 `
class classA{
private ClassB var1
private String var2
}
class classB{
private ClassC var3;
}
class classC{
private String var4;
}
现在我的xml映射看起来像
CruiseLine Mapping
<class name="ClassA"
auto-complete="false"
>
<map-to xml="Sample" />
<field name="var2">
<bind-xml node="attribute" name="var2" />
</field>
<field name="var4 from classC">
<I want a mapping for the var4 from classC to appear here. How do I do that ?>
</class>
` 如您所见,我想在xml元素Sample中从classC映射var4。我希望它是样本元素的一个元素。
`
<Sample var2="value">
<data var4="var4 value">
</Sample>
`
帮助表示赞赏!
答案 0 :(得分:1)
注意:我是EclipseLink JAXB (MOXy)主管,是JAXB 2 (JSR-222)专家组的成员。
Blaise:我以前没有使用过EclipseLink,但我认为我可以 如果采用EclipseLink相对简单,那就离开脚轮? 只是整个项目一直在使用Castor,所以它会 更一致。但是,请你详细说明Eclipselink。 谢谢。 - TYS
EclipseLink MOXy是一个JAXB(JSR-222)实现。查看您的问题,可以使用任何JAXB实现将此模型映射到所需的XML,如下所示:
<强> ClassA的强>
package forum9994762;
import javax.xml.bind.annotation.*;
@XmlRootElement(name="Sample")
@XmlAccessorType(XmlAccessType.FIELD)
public class ClassA {
@XmlElement(name="data")
private ClassB var1;
@XmlAttribute
private String var2;
}
<强> ClassB的强>
package forum9994762;
import javax.xml.bind.annotation.*;
@XmlAccessorType(XmlAccessType.FIELD)
public class ClassB {
@XmlAttribute(name="var4")
private ClassC var3;
}
<强> ClassC 强>
package forum9994762;
import javax.xml.bind.annotation.*;
@XmlAccessorType(XmlAccessType.FIELD)
public class ClassC {
@XmlValue
private String var4;
}
<强>演示强>
package forum9994762;
import java.io.File;
import javax.xml.bind.*;
public class Demo {
public static void main(String[] args) throws Exception {
JAXBContext jc = JAXBContext.newInstance(ClassA.class);
File xml = new File("src/forum9994762/input.xml");
Unmarshaller unmarshaller = jc.createUnmarshaller();
ClassA classA = (ClassA) unmarshaller.unmarshal(xml);
Marshaller marshaller = jc.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.marshal(classA, System.out);
}
}
<强> input.xml中/输出强>
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Sample var2="value">
<data var4="var4 value"/>
</Sample>
映射文件
作为Castor用户,您可能更愿意将元数据表示为外部映射文件。 EclipseLink MOXy提供了这样的扩展:
<强> binding.xml 强>
<?xml version="1.0" encoding="UTF-8"?>
<xml-bindings
xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/oxm"
package-name="forum9994762"
xml-accessor-type="FIELD">
<java-types>
<java-type name="ClassA">
<xml-root-element name="Sample"/>
<java-attributes>
<xml-element java-attribute="var1" name="data"/>
<xml-attribute java-attribute="var2"/>
</java-attributes>
</java-type>
<java-type name="ClassB">
<java-attributes>
<xml-attribute java-attribute="var3" name="var4"/>
</java-attributes>
</java-type>
<java-type name="ClassC">
<java-attributes>
<xml-value java-attribute="var4"/>
</java-attributes>
</java-type>
</java-types>
</xml-bindings>
<强>演示强>
package forum9994762;
import java.io.File;
import java.util.*;
import javax.xml.bind.*;
import org.eclipse.persistence.jaxb.JAXBContextFactory;
public class Demo {
public static void main(String[] args) throws Exception {
Map<String, Object> properties = new HashMap<String, Object>(1);
properties.put(JAXBContextFactory.ECLIPSELINK_OXM_XML_KEY, "forum9994762/binding.xml");
JAXBContext jc = JAXBContext.newInstance("forum9994762", ClassA.class.getClassLoader(), properties);
File xml = new File("src/forum9994762/input.xml");
Unmarshaller unmarshaller = jc.createUnmarshaller();
ClassA classA = (ClassA) unmarshaller.unmarshal(xml);
Marshaller marshaller = jc.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.marshal(classA, System.out);
}
}
更多信息
答案 1 :(得分:0)
如果在classA auto-complete=false
的mapping.xml文件中使用<class name="ClassA" auto-complete="false" >
,则必须告诉Castor marshaller如何单独映射ClassB和ClassC。
包括这两行可能会帮助您入门:
<class name="ClassB" auto-complete="true">
<map-to xml="class-B" />
</class>
<class name="ClassC" auto-complete="true">
<map-to xml="class-C" />
</class>
但是由于var4是ClassC的成员而不是ClassB,因此它将在xml输出层次结构中的一个深层。