你的位置:首页 > Java教程

[Java教程]JAVA开发Webservice——JAXB


   JAXB(Java API for

   JAXB 可以实现Java对象与

   下面来了解一下如何通过标注注解来完成 Marshal 和 UnMarshal 的过程。

首先看个小例子:

定义一个java类

 1 package jaxb; 2  3 import javax. 4 import javax. 5 import javax. 6  7 @ { 8  "name", 9  "age",10  "id"11  })12 @)13 public class Student14 {15   @)16   public int id = 1;17   @)18   public String name = "ldd";19   @)20   public int age = 18;21   @Override22   public String toString()23   {24     return "Student [id=" + id + ", name=" + name + ", age=" + age + "]";25   }26 }

Java To

 1 package jaxb; 2  3 import javax. 4 import javax. 5 import javax. 6  7 public class JavaTo 8 { 9   public static void main(String[] args) throws JAXBException10   {11     JAXBContext context = JAXBContext.newInstance(Student.class);12     Marshaller marshaller = context.createMarshaller();13     marshaller.setProperty(Marshaller.JAXB_ENCODING, "utf-8");//编码格式 14     marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);//是否格式化生成的15     marshaller.setProperty(Marshaller.JAXB_FRAGMENT, false);//是否省略16     Student student = new Student();17     marshaller.marshal(student, System.out);18   }19 }

输出结果如下:

<??><Student>  <Name>ldd</Name>  <Age>18</Age>  <ID>1</ID></Student>

 1 package jaxb; 2  3 import java.io.File; 4  5 import javax. 6 import javax. 7 import javax. 8  9 10 public class 11 {12   public static void main(String[] args) throws JAXBException13   {14     JAXBContext context = JAXBContext.newInstance(Student.class);15     Unmarshaller unmarshaller = context.createUnmarshaller();16     File file = new File("src/main/java/student.);17     Student student = (Student) unmarshaller.unmarshal(file);18     System.out.println(student);19   }20 }

 

  其实Marshal 和 UnMarshal的过程并不复杂,只需要从JAXBContext中获得Marshaller或Unmarshaller对象,就可以让JAXB帮我们来进行转换了。我们需要操作的主要内容是定义一个规则,告诉JAXB如何将一个类、按照什么样的格式转换为
   
@将一个Java类映射为一段

name            定义这个根节点的名称

namespace   定义这个根节点命名空间

@定义映射这个类中的何种类型需要映射到

 @

指定一个字段或get/set方法映射到

如,当一个类的

 

defaultValue  指定节点默认值

name             指定节点名称

namespace    指定节点命名空间

required         是否必须(默认为false)

 nillable  该字段是否包含 nillable="true" 属性(默认为false)

   type               定义该字段或属性的关联类型

 @ 指定一个字段或get/set方法映射到 

name             指定属性名称

namespace    指定属性命名空间

required         是否必须(默认为false)

 @

定义某一字段或属性不需要被映射为

如,当一个类的

 
 @ 定义映射的一些相关规则 

propOrder        指定映射

factoryClass     指定UnMarshal时生成映射类实例所需的工厂类,默认为这个类本身

factoryMethod  指定工厂类的工厂方法

name               定义

namespace      指定Schema中的命名空间

 @ 

为数组元素或集合元素定义一个父节点。如,类中有一元素为List items,若不加此注解,该元素将被映射为

    <items>...</items>

    <items>...</items>

这种形式,此注解可将这个元素进行包装,如:

    @    @    public List items;

将会生成这样的

    <items>

        <item>...</item>

        <item>...</item>

    </items>

 
 @

自定义某一字段或属性映射到

如,类中包含一个接口,我们可以定义一个适配器(继承自javax.

 
 @配置整个包的namespace,这个注解需放在package-info.java文件中。