或许你想要做的第一件事情就是解析一个某U类型的XML文档Q用dom4j很容易做到。请看下面的C代码Q?br />
import java.net.URL;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;

public class Foo {

    public Document parse(URL url) throws DocumentException {
        SAXReader reader = new SAXReader();
        Document document = reader.read(url);
        return document;
    }
}

使用q代器(IteratorsQ?/h4>
    我们可以通过多种Ҏ来操作XML文档Q这些方法返回java里标准的q代器(IteratorsQ。例如:

public void bar(Document document) throws DocumentException {
        Element root = document.getRootElement();
        //q代根元素下面的所有子元素
        for ( Iterator i = root.elementIterator(); i.hasNext(); ) {
            Element element = (Element) i.next();
            //处理代码
        }

        //q代根元素下面名UCؓ"foo"的子元素
        for ( Iterator i = root.elementIterator( "foo" ); i.hasNext(); ) {
            Element foo = (Element) i.next();
            //处理代码
        }

        // q代根元素的属性attributesQ元?br />        for ( Iterator i = root.attributeIterator(); i.hasNext(); ) {
            Attribute attribute = (Attribute) i.next();
            // do something
        }
     }

强大的XPathD


    在dom4j中XPath可以表示出在XML树状l构中的Document或者Q意的节点QNodeQ(例如QAttributeQElement 或者ProcessingInstruction{)。它可以使在文档中复杂的操作仅通过一行代码就可以完成。例如:

public void bar(Document document) {
        List list = document.selectNodes( "http://foo/bar" );

        Node node = document.selectSingleNode( "http://foo/bar/author" );

        String name = node.valueOf( "@name" );
    }

    如果你想得到一个XHTML文档中的所有超文本链接Qhypertext linksQ你可以使用下面的代码:

    public void findLinks(Document document) throws DocumentException {

        List list = document.selectNodes( "http://a/@href" );

        for (Iterator iter = list.iterator(); iter.hasNext(); ) {
            Attribute attribute = (Attribute) iter.next();
            String url = attribute.getValue();
        }
    }

    如果你需要关于XPath语言的Q何帮助,我们强烈推荐q个站点Zvon tutorial他会通过一个一个的例子引导你学习?br />

快速遍历(Fast LoopingQ?/h4>

如果你不得不遍历一个非常大的XML文档Q然后才L行,我们你用快速遍历方法(fast looping methodQ,它可以避免ؓ每一个@环的节点创徏一个P代器对象,如下所C:

public void treeWalk(Document document) {
        treeWalk( document.getRootElement() );
    }

    public void treeWalk(Element element) {
        for ( int i = 0, size = element.nodeCount(); i < size; i++ ) {
            Node node = element.node(i);
            if ( node instanceof Element ) {
                treeWalk( (Element) node );
            }
            else {
                // do something....
            }
        }
    }

生成一个新的XML文档对象


    在dom4j中你可能常常希望用程序生成一个XML文档对象Q下面的E序Zq行了示范:

import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;

public class Foo {

    public Document createDocument() {
        Document document = DocumentHelper.createDocument();
        Element root = document.addElement( "root" );

        Element author1 = root.addElement( "author" )
            .addAttribute( "name", "James" )
            .addAttribute( "location", "UK" )
            .addText( "James Strachan" );
        
        Element author2 = root.addElement( "author" )
            .addAttribute( "name", "Bob" )
            .addAttribute( "location", "US" )
            .addText( "Bob McWhirter" );

        return document;
    }
}

一个文档对象写入文件中


    一个文档对象写入Writer对象的一个简单快速的途径是通过write()Ҏ?br />
        FileWriter out = new FileWriter( "foo.xml" );
        document.write( out );

如果你想改变输出文g的排版格式,比如你想要一个漂亮的格式或者是一个紧凑的格式Q或者你想用Writer 对象或者OutputStream 对象来操作,那么你可以用XMLWriter cR?br />
import org.dom4j.Document;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;

public class Foo {

    public void write(Document document) throws IOException {

        // 写入文g
        XMLWriter writer = new XMLWriter(
            new FileWriter( "output.xml" )
        );
        writer.write( document );
        writer.close();


        // 以一U优雅的格式写入System.out对象
        OutputFormat format = OutputFormat.createPrettyPrint();
        writer = new XMLWriter( System.out, format );
        writer.write( document );

        // 以一U紧凑的格式写入System.out对象
        format = OutputFormat.createCompactFormat();
        writer = new XMLWriter( System.out, format );
        writer.write( document );
    }
}

转化为字W串Q或者从字符串{?/h4>
    如果你有一个文档(DocumentQ对象或者Q何一个节点(NodeQ对象的引用QreferenceQ,象属性(AttributeQ或者元素(ElementQ,你可以通过asXML()Ҏ把它转化Z个默认的XML字符Ԍ

        Document document = ...;
        String text = document.asXML();

如果你有一些XML内容的字W串表示Q你可以通过DocumentHelper.parseText()Ҏ它重新转化为文档(DocumentQ对象:

        String text = "<person> <name>James</name> </person>";
        Document document = DocumentHelper.parseText(text);

通过XSLT样式化文档(DocumentQ?/h4>

    使用Sun公司提供?a class="l2" target="_blank">JAXP APIXSLT 应用到文档(DocumentQ上是很单的。它允许你用Q何的XSLT引擎Q例如:Xalan或SAXON{)来开发。下面是一个用JAXP创徏一个{化器QtransformerQ,然后它应用到文档(DocumentQ上的例子:

import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;

import org.dom4j.Document;
import org.dom4j.io.DocumentResult;
import org.dom4j.io.DocumentSource;

public class Foo {

    public Document styleDocument(
        Document document, 
        String stylesheet
    ) throws Exception {

        // 使用 JAXP 加蝲转化?br />        TransformerFactory factory = TransformerFactory.newInstance();
        Transformer transformer = factory.newTransformer( 
            new StreamSource( stylesheet ) 
        );

        // 现在来样式化一个文档(DocumentQ?br />        DocumentSource source = new DocumentSource( document );
        DocumentResult result = new DocumentResult();
        transformer.transform( source, result );

        // q回l过样式化的文档QDocumentQ?br />        Document transformedDoc = result.getDocument();
        return transformedDoc;
    }
}