4)DOM4J http://dom4j.sourceforge.net
雖然DOM4J代表了完全獨立的開發結果,但最初,它是JDOM的一種智能分支。它合併了許多超出基本XML文檔表示的功能,包括集成的XPath支持、XML Schema支持以及用於大文檔或流化文檔的基於事件的處理。它還提供了構建文檔表示的選項,它通過DOM4J API和標準DOM接口具有並行訪問功能。從2000下半年開始,它就一直處於開發之中。
爲支持所有這些功能,DOM4J使用接口和抽象基本類方法。DOM4J大量使用了API中的Collections類,但是在許多情況下,它還提供一些替代方法以允許更好的性能或更直接的編碼方法。直接好處是,雖然DOM4J付出了更復雜的API的代價,但是它提供了比JDOM大得多的靈活性。
在添加靈活性、XPath集成和對大文檔處理的目標時,DOM4J的目標與JDOM是一樣的:針對Java開發者的易用性和直觀操作。它還致力於成爲比JDOM更完整的解決方案,實現在本質上處理所有Java/XML問題的目標。在完成該目標時,它比JDOM更少強調防止不正確的應用程序行爲。
DOM4J是一個非常非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一個開放源代碼的軟件。如今你可以看到越來越多的Java軟件都在使用DOM4J來讀寫XML,特別值得一提的是連Sun的JAXM也在用DOM4J.
package com.lr.utils;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.dom4j.Attribute;
import org.dom4j.Element;
import org.dom4j.io.DOMReader;
import org.dom4j.Document;
import org.xml.sax.SAXException;
import com.lr.bean.BookInfo;
public class Dom4j {
//公有的獲取 所有書本信息的方法
@SuppressWarnings("unchecked")
public List<BookInfo> getInfo(){
List<BookInfo> list=new ArrayList<BookInfo>();
try {
//DOM解析
DOMReader reader=new DOMReader();
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
//通過文檔構建器 創建一個 document 樹
Document doc=reader.read(factory.newDocumentBuilder().parse(new File("books.xml")));
Element rootElement=doc.getRootElement();//獲取根元素
//迭代取值
Iterator it=rootElement.elementIterator();
Object ele;
BookInfo bk=null;
Element e;
Attribute attr;
while(it.hasNext()){ //含有子節點
ele=it.next();
if("book".equals(((Element) ele).getName())){ //元素名等於book
bk=new BookInfo();
//獲取書本的所有屬性
for(Iterator attrList=((org.dom4j.Element) ele).attributeIterator();attrList.hasNext();){
attr=(Attribute) attrList.next();
if("id".equals(attr.getName())){
bk.setId(attr.getValue());
}
}
//獲取書本的所有子節點
for(Iterator el=((org.dom4j.Element) ele).elementIterator();el.hasNext();){
e=(Element) el.next();
if("bookName".equals(e.getName())){
bk.setBookName(((org.dom4j.Element) e).getTextTrim());
}else if("price".equals(e.getName())){
bk.setPrice(((org.dom4j.Element) e).getTextTrim());
}else if("bookPub".equals(e.getName())){
bk.setBookPub(((org.dom4j.Element) e).getTextTrim());
}
}
}
list.add(bk);
}
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ParserConfigurationException e) {
e.printStackTrace();
}
return list;
}
public static void main(String[] args){
Dom4j d=new Dom4j();
System.out.println(d.getInfo());
}
}