含有List类型对象
含有List类型
一般来说,一个Order不止含有一个Product,就需要使用到 List 了。
@Test
public void test2() throws JAXBException {
Product p1 = new Product();
p1.setId("11021");
p1.setName("Apple");
Product p2 = new Product();
p2.setId("11022");
p2.setName("Banana");
List<Product> list = Arrays.asList(p1,p2);
Order2 order = new Order2();
order.setId("1102");
order.setPrice(45.67);
order.setProduct(list);
JAXBContext context = JAXBContext.newInstance(Order2.class);
Marshaller marshaller = context.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.marshal(order, System.out);
}
对象 Order2 的第三个字段是 List 类型。Product和上例中的一样。
@XmlRootElement(name = "Order")
public class Order2 {
private String id;
private Double price;
private List<Product> product;
//setters, getters
}
生成的XML中 product 重复出现多次。
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Order>
<id>1102</id>
<price>45.67</price>
<product id="11021">
<name>Apple</name>
</product>
<product id="11022">
<name>Banana</name>
</product>
</Order>
循环数据被包裹
上例中的Product是散落着的数据,有时候可能需要将其包裹起来,这时只需要改动 Order 对象。
@XmlRootElement(name = "Order")
@XmlAccessorType(XmlAccessType.FIELD)
public class Order3 {
private String id;
private Double price;
@XmlElementWrapper(name = "Products")
private List<Product> product;
编组过程和上例中的相同,生成的XML包含了一个 Products 包裹着所有的 Product
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Order>
<id>1102</id>
<price>45.67</price>
<Products>
<product id="11021">
<name>Apple</name>
</product>
<product id="11022">
<name>Banana</name>
</product>
</Products>
</Order>