JAXB中的@XmlRootElement注解詳解


Java代碼
  1. @Retention(value=RUNTIME)  
  2. @Target(value=TYPE)  
  3. public @interface XmlRootElement  
  4.   
  5. @Inherited  
  6. @Retention(value=RUNTIME)  
  7. @Target(value={PACKAGE,TYPE})  
  8. public @interface XmlAccessorType  


XmlRootElement: 將類或枚舉類型映射到 XML 元素。JAXB中的注解,用來根據java類生成xml內容。 

當使用 @XmlRootElement 注釋對頂層類或枚舉類型進行注釋時,類型值被表示為 XML 文檔中的 XML 元素。 

JAXB Annotation 

  • @XmlRootElement   // xml 文件的根元素
  • @XmlElement
  • @XmlAccessorType  // 控制默認情況下是否對字段或 Javabean 屬性進行系列化。
  • @XmlTransient
  • @XmlJavaTypeAdaptor:參考Using JAXB 2.0's XmlJavaTypeAdapter



XmlAccessorType  
默認規則: 
默認情況下,如果包中不存在 @XmlAccessorType,那么假定使用以下包級別注釋。 
@XmlAccessorType(XmlAccessType.PUBLIC_MEMBER) 
默認情況下,如果類中不存在 @XmlAccessorType,並且沒有任何超類是使用 @XmlAccessorType 注釋的,則假定在類中使用以下默認注釋: 
@XmlAccessorType(XmlAccessType.PUBLIC_MEMBER) 
可能值: 
FIELD:    JAXB 綁定類中的每個非靜態、非瞬態字段將會自動綁定到 XML,除非由 XmlTransient 注釋。 
NONE:     所有字段或屬性都不能綁定到 XML,除非使用一些 JAXB 注釋專門對它們進行注釋。 
PROPERTY: JAXB 綁定類中的每個獲取方法/設置方法對將會自動綁定到 XML,除非由 XmlTransient 注釋。 
PUBLIC_MEMBER:每個公共獲取方法/設置方法對和每個公共字段將會自動綁定到 XML,除非由 XmlTransient 注釋。 

應用參考:http://blog.sina.com.cn/s/blog_4051f5dc0100ju0a.html 

Java代碼
  1. package jaxb;  
  2. import javax.xml.bind.annotation.XmlAccessorType;  
  3. import javax.xml.bind.annotation.XmlRootElement;  
  4. import javax.xml.bind.annotation.XmlAccessType;  
  5.   
  6. @XmlRootElement // 必須要標明這個元素  
  7. @XmlAccessorType(XmlAccessType.FIELD)  
  8. public class Boy {     
  9.     String name = "CY";  
  10. }  
  11.   
  12. package jaxb;  
  13.   
  14. import java.io.StringReader;  
  15. import javax.xml.bind.JAXBContext;  
  16. import javax.xml.bind.JAXBException;  
  17. import javax.xml.bind.Marshaller;  
  18. import javax.xml.bind.Unmarshaller;  
  19.   
  20. public class JAXBTest {  
  21.   
  22.     public static void main(String[] args) throws JAXBException {  
  23.         JAXBContext context = JAXBContext.newInstance(Boy.class);  
  24.          
  25.         Marshaller marshaller = context.createMarshaller();  
  26.         Unmarshaller unmarshaller = context.createUnmarshaller();  
  27.          
  28.         Boy boy = new Boy();  
  29.         marshaller.marshal(boy, System.out);  
  30.         System.out.println();  
  31.          
  32.         String xml = "<boy><name>David</name></boy>";  
  33.         Boy boy2 = (Boy) unmarshaller.unmarshal(new StringReader(xml));  
  34.         System.out.println(boy2.name);  
  35.     }  
  36. }  


執行結果: 
<?xml version="1.0" encoding="UTF-8" standalone="yes"?><boy><name>CY</name></boy> 
David 
(先 是marshall成 xml文件,再是把 xml 文件 unmarshal 成 java object。) 

改動一: 
修改@XmlAccessorType(XmlAccessType.FIELD)  --> @XmlAccessorType(XmlAccessType.PROPERTY) 
意思是只有 屬性 才能被轉換成 xml 中的標簽。 

所以再運行的結果是: 
<?xml version="1.0" encoding="UTF-8" standalone="yes"?><boy/> 
CY 
就是說 java object 轉換成 xml 的時候,name 不是屬性(因為沒有 get set方法),所以name不轉換成標簽。 

改動二: 
在 改動一 的基礎上,給name屬性添加 get set 方法。 再運行,結果為: 
<?xml version="1.0" encoding="UTF-8" standalone="yes"?><boy><name>CY</name></boy> 
David 
由 此 可見 @XmlAccessorType 這個annotation 的作用。 

改動三: 
在改動二 的基礎上,給Boy 再添加一個field, int age=10, 即: 

Java代碼   收藏代碼
  1. package jaxb;  
  2.   
  3. import javax.xml.bind.annotation.XmlAccessorType;  
  4. import javax.xml.bind.annotation.XmlRootElement;  
  5. import javax.xml.bind.annotation.XmlAccessType;  
  6.   
  7. @XmlRootElement  
  8. @XmlAccessorType(XmlAccessType.PROPERTY)  
  9. public class Boy {     
  10.     String name = "CY";  
  11.     int age = 10;  
  12.     public String getName() {  
  13.         return name;  
  14.     }  
  15.     public void setName(String name) {  
  16.         this.name = name;  
  17.     }  
  18. }  


顯然,這個age 是不會被 轉化 到xml 文件中的。解決辦法是: 

Java代碼   收藏代碼
  1. import javax.xml.bind.annotation.XmlAccessorType;  
  2. import javax.xml.bind.annotation.XmlElement;  
  3. import javax.xml.bind.annotation.XmlRootElement;  
  4. import javax.xml.bind.annotation.XmlAccessType;  
  5.   
  6. @XmlRootElement // bixude  
  7. @XmlAccessorType(XmlAccessType.PROPERTY)  
  8. public class Boy {  
  9.      
  10.     String name = "CY";  
  11.     @XmlElement  
  12.     int age = 10;  
  13.     public String getName() {  
  14.         return name;  
  15.     }  
  16.   
  17.     public void setName(String name) {  
  18.         this.name = name;  
  19.     }  
  20.   
  21. }  



加上 @XmlElement annotation. 運行結果為: 
<?xml version="1.0" encoding="UTF-8" standalone="yes"?><boy><age>10</age> <name>CY</name></boy> 
David 

對於根元素,可以設置屬性: 
@XmlRootElement(name="b" nameSpace="http://test") 
這樣,在生成的xml文件中,<boy> 標簽 就會變為 <b> 標簽。並且加上一個命名空間。 


下面解釋 @XmlJavaTypeAdaptor 的作用: 

Java代碼   收藏代碼
  1. @XmlRootElement  
  2. @XmlAccessorType(XmlAccessType.PROPERTY)  
  3. public class Boy {  
  4.      
  5.     private String name = "CY";  
  6.   
  7.     private Address address; // 是一個接口  
  8.      
  9.     public String getName() {  
  10.         return name;  
  11.     }  
  12.   
  13.     public void setName(String name) {  
  14.         this.name = name;  
  15.     }  
  16.   
  17. }  


在 java object 轉換成 xml 的時候,接口Address 無法被轉換。 
所以 這里要加上 @XmlJavaTypeAdapter(AddressAdapter.class) 
所以 要多寫一個AddressAdaptor 類。 
這個類會返回Address接口的一個具體實現類的對象。 

這 就是 @XmlJavaTypeAdapter 的作用。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM