使用XStream注解實現Java對象與XML互相轉換的代碼示例


  本文記錄一下使用xstream這個api的注解特性對Java對象與XML字符串相互轉換的一些代碼示例。
    我們很多人都處理過XML文件,也有很多非常成熟的第三方開源軟件。如:jdom、dom4j等。雖然他們的功能非常強大,但在使用上還是有點不那么習慣。對於格式比較固定的XML文檔,它的結構沒有變化或是很少變化,這時將它轉換成我們熟悉的Java對象來操作的話,會使工作變得更容易一些,而xstream正好可以滿足這一點。
    本文所用xstream的版本為:1.4.7

   <dependency>
       <groupId>com.thoughtworks.xstream</groupId>
       <artifactId>xstream</artifactId>
       <version>1.4.7</version>
   </dependency>

    還是以之前的book XML為例,先上代碼。

import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamAsAttribute;

@XStreamAlias("book")
public class Book {

    // 別名注解,這個別名就是XML文檔中的元素名,Java的屬性名不一定要與別名一致
    @XStreamAlias("name")
    private String name;
    
    @XStreamAlias("author")
    private String author;
    
    // 屬性注解,此price就是book的屬性,在XML中顯示為:<book price="108">
    @XStreamAsAttribute()
    @XStreamAlias("price")
    private String price;

    省略get和set方法
}


import java.util.List;

import com.thoughtworks.xstream.annotations.XStreamAlias;
import com.thoughtworks.xstream.annotations.XStreamImplicit;

@XStreamAlias("books")
public class Books {

    // 隱式集合,加上這個注解可以去掉book集合最外面的<list></list>這樣的標記
    @XStreamImplicit
    private List<Book> list;

    省略get和set方法
}


import java.util.List;

import com.thoughtworks.xstream.XStream;
import com.thoughtworks.xstream.io.xml.DomDriver;

public class XStreamHandle {

    private static final String xmlString = "<books><book price=\"108\"><name>Java編程思想</name><author>Bruce Eckel</author></book><book price=\"52\"><name>Effective Java</name><author>Joshua Bloch</author></book><book price=\"118\"><name>Java 7入門經典</name><author>Ivor Horton</author></book></books>";

    public static String toXml(Object obj) {
        XStream xstream = new XStream(new DomDriver("utf8"));
        xstream.processAnnotations(obj.getClass()); // 識別obj類中的注解
        /*
         // 以壓縮的方式輸出XML
         StringWriter sw = new StringWriter();
         xstream.marshal(obj, new CompactWriter(sw));
         return sw.toString();
         */
        // 以格式化的方式輸出XML
        return xstream.toXML(obj);
    }
    
    public static <T> T toBean(String xmlStr, Class<T> cls) {
        XStream xstream = new XStream(new DomDriver());
        xstream.processAnnotations(cls);
        @SuppressWarnings("unchecked")
        T t = (T) xstream.fromXML(xmlStr);
        return t;
    }
    
    public static void main(String[] args) {
        Books books = toBean(xmlString, Books.class);
        List<Book> list = books.getList();
        for(Book book : list) {
            System.out.println("name=" + book.getName() + "\tauthor=" + book.getAuthor()
                    + "\tprice=" + book.getPrice());
        }
        System.out.println(toXml(books));
    }
}


    除了上面示例中用的注解,xstream還有下面幾種注解也經常用到。
    @XstreamOmitField 忽略字段
    這相當於設置某些字段為臨時屬性,在轉換中不再起作用。
    @XStreamConverter(XXX.class)  轉換器
    XXX.class是一個實現了com.thoughtworks.xstream.converters.Converter接口的轉換器,對某些類型的值進行轉換,比如布爾值類型的truefalse,如果不加轉換器,默認生成的值就是true或false。xstream自帶了BooleanConverter轉換器,可以將默認值轉換成需要的文本值,如果xstream沒有需要的轉換器就得自己實現Converter接口來自定義轉換器。
    根據大象的經驗,為了少給自己找麻煩,比如避免使用轉換器,最好將與XML元素或屬性對應的Java對象屬性都設置成String類型,當然列表還是要定義成List類型的。只要不是特別奇葩,一般情況下,示例部分就能滿足絕大部分的需求。
    本文為菠蘿大象原創,如要轉載請注明出處。http://www.blogjava.net/bolo


免責聲明!

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



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