解讀JAXBContext類

解讀JAXBContext類
JAXBContext是整個JAXB API的入口.主要用來構建JAXB實例(newInstance()),並提供與XML/Java綁定信息相關的抽象方法,如編組(createMarshaller())、解組(createUnmarshaller())和驗證(createValidator()).其中與驗證相關的方法已廢棄(Deprecated),被Validator所替代.
1. newInstance(): 應用程序可以通過多種途徑獲得JAXBContext實例,它們擁有相同的函數名,只是參數不同.
(1) 創建JAXB實例,最常見的方式是傳入特定的class

JAXBContext context = JAXBContext.newInstance(User.class);

(2) 如果存在同名的Java對象,則可以指定完整路徑:

JAXBContext context = JAXBContext.newInstance(com.liantuo.contrast.util.jaxb.User.class);

(3) 多個對象需要註冊:

1)使用下面方法進行對象構造:

JAXBContext context = JAXBContext.newInstance(User.class,Person.class);

2)對某一個package包下所有的對象編組:

JAXBContext context = JAXBContext.newInstance("com.liantuo.contrast.util.jaxb");

注意需要在指定的目錄下添加jaxb.index文件 和 ObjectFactory.java類
jaxb.index 文件如下:

User
Person

ObjectFactory.java類如下:

package com.liantuo.contrast.util.jaxb;
import javax.xml.bind.annotation.XmlRegistry;

@XmlRegistry
public class ObjectFactory {

    public ObjectFactory() {

    }

    public User createUser() {
        return new User();
    }

    public Person createPerson(){
        return new Person();
    }
    
}

測試:

package com.liantuo.contrast.util.jaxb;

import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Unmarshaller;
import java.io.StringReader;

public class demo {
    public static void main(String[] args) throws ClassNotFoundException {
        User user = new User();
        user.setId(1);
        user.setName("lili");
        user.setAge(18);
        JaxbUtil jaxbUtil = new JaxbUtil();
        String xml = jaxbUtil.javaToXml(user);
        System.out.println("User對象轉XML的結果:" + xml);

        Person p  = new Person();
        p.setId(2);
        p.setName("lucy");
        p.setAge(19);
        String x = jaxbUtil.javaToXml(p);
        System.out.println("Person對象轉XML的結果:" + x);

        try {
            JAXBContext context = JAXBContext.newInstance("com.liantuo.contrast.util.jaxb");
            Unmarshaller unmarshaller = context.createUnmarshaller();
            Object un = unmarshaller.unmarshal(new StringReader(xml));
            System.out.println(un);
            Object un1 = unmarshaller.unmarshal(new StringReader(x));
            System.out.println(un1);
        } catch (JAXBException e) {
            e.printStackTrace();
        }

    }
}

執行結果:

傳入完整包名.這時候並不是指定的包中所有的Class都會用來創建JAXBContext.按照JAXB的規範,我們需要在對應的包中創建一個jaxb.index文件,然後在其中指定創建JAXBContext時需要用到的Class,每個Class名稱佔一行.否則,會報錯:"[javax.xml.bind.JAXBException: "com.liantuo.contrast.util.jaxb" 不包含 ObjectFactory.class 或 jaxb.index]" (如下圖)

詳細參數參考:http://blog.bdoughan.com/2012/07/jaxb-and-root-elements.html

3)對多個package包下所有的對象編組:

JAXBContext instance = JAXBContext.newInstance("com.example.bean:com.example.pojo");

注意:完整包名之間使用冒號分隔開

2. createMarshaller()創建一個Marshaller對象,用於將Java內容轉換爲XML數據.
對使用工廠方法手動創建的內容進行編組與unmarshal操作結果的內容進行編組沒有本質區別.客戶端可以將Java內容編組成java.io.OutputStream或者java.io.Writer的XML數據.編組程序可以生成已經註冊號的SAX2事件流,也可以生成一個DOM節點對象.
3. createUnmarshaller()創建一個可以用來將XML數據轉換爲java內容樹的Unmarshaller對象.
該方法允許將模式中聲明的任何全局XML元素解組爲實例文檔的根元素.
4. createBinder()創建一個可用於關聯/原地解組/編組操作的Binder對象.如果不傳參數,默認使用W3C DOM創建一個Binder.
5. JAXBContext 爲了性能上的考慮,將會對JAXBContext做緩存,不過緩存使用到了WeakReference,不用擔心GC問題. 
後續會對JAXBContext做緩存進行介紹

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章