亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何正確的使用JAXB

發布時間:2020-12-02 16:47:55 來源:億速云 閱讀:145 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關如何正確的使用JAXB,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

一、jaxb是什么 

    JAXB是Java Architecture for XML Binding的縮寫。可以將一個Java對象轉變成為XML格式,反之亦然。 
    我們把對象與關系數據庫之間的映射稱為ORM,其實也可以把對象與XML之間的映射稱為OXM(Object XML Mapping)。原來JAXB是Java EE的一部分,在JDK1.6中,SUN將其放到了Java SE中,這也是SUN的一貫做法。JDK1.6中自帶的這個JAXB版本是2.0,比起1.0(JSR 31)來,JAXB2(JSR 222)用JDK5的新特性Annotation來標識要作綁定的類和屬性等,這就極大簡化了開發的工作量。 

二、jaxb應用模式 

    在JAVA EE 5\6中,jaxb可以很方便的與jax-rs、jax-ws集成,極大的簡化了web service接口的開發工作量。 

三、jaxb代碼舉例 

首先定義兩個示例類ClassA,ClassB,用于后續的示例演示

package com.bjpowernode.test;

public class ClassA {
  private int classAId;
  private String classAName;

  private ClassB classB;

  public int getClassAId() {
    return classAId;
  }

  public void setClassAId(int classAId) {
    this.classAId = classAId;
  }

  public String getClassAName() {
    return classAName;
  }

  public void setClassAName(String classAName) {
    this.classAName = classAName;
  }

  public ClassB getClassB() {
    return classB;
  }

  public void setClassB(ClassB classB) {
    this.classB = classB;
  }
}
package com.bjpowernode.test;

public class ClassB {
  private int classBId;
  private String classBName;

  public int getClassBId() {
    return classBId;
  }

  public void setClassBId(int classBId) {
    this.classBId = classBId;
  }

  public String getClassBName() {
    return classBName;
  }

  public void setClassBName(String classBName) {
    this.classBName = classBName;
  }
}

用于序列化的XmlUtil

package com.bjpowernode.test;

import java.io.StringReader;
import java.io.StringWriter;

import javax.xml.bind.*;

public class XmlUtil {

  public static String toXML(Object obj) {
    try {
      JAXBContext context = JAXBContext.newInstance(obj.getClass());

      Marshaller marshaller = context.createMarshaller();
      marshaller.setProperty(Marshaller.JAXB_ENCODING, "UTF-8");// //編碼格式
      marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);// 是否格式化生成的xml串
      marshaller.setProperty(Marshaller.JAXB_FRAGMENT, false);// 是否省略xm頭聲明信息
      StringWriter writer = new StringWriter();
      marshaller.marshal(obj, writer);
      return writer.toString();
    } catch (Exception e) {
      throw new RuntimeException(e);
    }
  }

  @SuppressWarnings("unchecked")
  public static <T> T fromXML(String xml, Class<T> valueType) {
    try {
      JAXBContext context = JAXBContext.newInstance(valueType);
      Unmarshaller unmarshaller = context.createUnmarshaller();
      return (T) unmarshaller.unmarshal(new StringReader(xml));
    } catch (Exception e) {
      throw new RuntimeException(e.getMessage());
    }
  }
}

調用如下:

package com.bjpowernode.test;

public class MainRun {

  /**
   * @param args
   */
  public static void main(String[] args) {

    ClassB classB = new ClassB();
    classB.setClassBId(22);
    classB.setClassBName("B2");

    ClassA classA = new ClassA();
    classA.setClassAId(11);
    classA.setClassAName("A1");
    classA.setClassB(classB);

    System.out.println(XmlUtil.toXML(classA));
  }

}

輸出結果如下:

<&#63;xml version="1.0" encoding="UTF-8" standalone="yes"&#63;>
<classA>
  <classAId>11</classAId>
  <classAName>A1</classAName>
  <classB>
    <classBId>22</classBId>
    <classBName>B2</classBName>
  </classB>
</classA>

這里要注意以下幾點

1.要序列化的類加上 @XmlRootElement注解,否則會報錯(錯誤提示很清晰,這里就不貼出來了)
2.JAXB序列化XML時  默認序列化getter和setter,且getter和setter必須成對出現才會被序列化
3.屬性名稱,默認序列化出來的類和屬性名稱默認是首字母轉換為小寫,若需要控制屬性名稱需要在getter或setter上使用 @XmlElement(name="ClassAId") 指定名稱,這里要注意的是@XmlElement放置在getter或setter上都行,但只能放一個,也就是說不能同時在getter和setter上使用@XmlElement注解
4.如何控制根節點名稱?
使用@XmlRootElement指定name屬性即可,如@XmlRootElement(name="ClassA")
5.怎么添加命名空間
使用@XmlRootElement(namespace="com.bjpowernode.test") 指定namespace屬性
6.怎么精確控制每個屬性名稱
JAXB自動轉化為首字母小寫會導致不可預料的屬性名稱出現, 不嫌麻煩的話為每個屬性設置@XmlElement(name=""),想省事的話使用Field
7.怎么樣實現序列化時使用Field字段而不是使用setter和getter
在要使用的類上面加上@XmlAccessorType(XmlAccessType.FIELD)注解,并指定為XmlAccessType.FIELD,這里強烈推薦使用@XmlAccessorType(XmlAccessType.FIELD)注解,因為這樣你可以精確的控制每個元素的名稱,而不需要為每個屬性去設置@XmlElement(name="")注解,當然也可以在Field上使用@XmlElement注解
下面給出使用了使用如上注解后的代碼示例

@XmlRootElement(namespace="com.bjpowernode.test")
@XmlAccessorType(XmlAccessType.FIELD)
public class ClassA {
  private int classAId;
  
  @XmlElement(name="ClassAName")
  private String classAName;

  private ClassB classB;

  public int getClassAId() {
    return classAId;
  }
  public void setClassAId(int classAId) {
    this.classAId = classAId;
  }

  public String getClassAName() {
    return classAName;
  }

  public void setClassAName(String classAName) {
    this.classAName = classAName;
  }

  public ClassB getClassB() {
    return classB;
  }

  public void setClassB(ClassB classB) {
    this.classB = classB;
  }
}

@XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public class ClassB {
  private int ClassBId;
  private String ClassBName;

  public int getClassBId() {
    return ClassBId;
  }

  public void setClassBId(int classBId) {
    this.ClassBId = classBId;
  }

  public String getClassBName() {
    return ClassBName;
  }

  public void setClassBName(String classBName) {
    this.ClassBName = classBName;
  }
}

輸出xml為

<&#63;xml version="1.0" encoding="UTF-8" standalone="yes"&#63;>
<ns2:classA xmlns:ns2="com.bjpowernode.test">
  <classAId>11</classAId>
  <ClassAName>A1</ClassAName>
  <classB>
    <ClassBId>22</ClassBId>
    <ClassBName>B2</ClassBName>
  </classB>
</ns2:classA>

上述就是小編為大家分享的如何正確的使用JAXB了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

洪雅县| 阳信县| 陕西省| 龙门县| 通城县| 合作市| 灵寿县| 乐陵市| 湘潭市| 临沧市| 阳江市| 德庆县| 万载县| 盐城市| 大安市| 大同市| 历史| 甘洛县| 丰都县| 巴塘县| 永城市| 柳林县| 宁晋县| 冷水江市| 海伦市| 石首市| 都安| 黄山市| 越西县| 唐海县| 宜兴市| 卢氏县| 大关县| 称多县| 河西区| 开封市| 邹城市| 乌鲁木齐县| 赤城县| 高邑县| 武安市|