• JAXB注解 @XmlRootElement 及XML文件解析详解


    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 的作用。

  • 相关阅读:
    一份简单的自我评述
    从诞总那儿得到的一些感悟
    2021秋软件工项目选题
    LeNet 网络进行猫狗大战
    不平行的直线
    切长条
    纪念品分组
    奇♂妙拆分
    Qt 一些日期格式转换不精确
    windbg 查看崩溃日志
  • 原文地址:https://www.cnblogs.com/yuyu666/p/10058419.html
Copyright © 2020-2023  润新知