DOM4j介绍

      Dom4j is an easy to use, open source library for working with XML, XPath and XSLT on the Java platform using the Java Collections Framework and with full support for DOM, SAX and JAXP. 
     
它的主要接口都在org.dom4j这个包里定义:
Attribute
Attribute定义了XML的属性
Branch
Branch为能够包含子节点的节点如XML元素(Element)和文档(Docuemnts)定义了一个公共的行为,
CDATA
CDATA 定义了XML CDATA 区域
CharacterData
CharacterData是一个标识借口,标识基于字符的节点。如CDATA,Comment, Text.
Comment
Comment 定义了XML注释的行为
Document
定义了XML文档
DocumentType
DocumentType 定义XML DOCTYPE声明
Element
Element定义XML 元素
ElementHandler
ElementHandler定义了 Element 对象的处理器
ElementPath
ElementHandler 使用,用于取得当前正在处理的路径层次信息
Entity
Entity定义 XML entity
Node
Node为所有的dom4j中XML节点定义了多态行为
NodeFilter
NodeFilter 定义了在dom4j节点中产生的一个滤镜或谓词的行为(predicate)
ProcessingInstruction
ProcessingInstruction 定义 XML 处理指令.
Text
Text 定义XML 文本节点.
Visitor
Visitor 用于实现Visitor模式.
XPath
XPath 在分析一个字符串后会提供一个XPath 表达式

 

这些接口所在的包结构如下:

interface java.lang. Cloneable
  • interface org.dom4j.Node
    • interface org.dom4j.Attribute
    • interface org.dom4j.Branch
      • interface org.dom4j.Document
      • interface org.dom4j.Element

    • interface org.dom4j.CharacterData
      • interface org.dom4j.CDATA
      • interface org.dom4j.Comment
      • interface org.dom4j.Text
    • interface org.dom4j.DocumentType
    • interface org.dom4j.Entity
    • interface org.dom4j.ProcessingInstruction

 

为了容易叙述,现在我用Dom4j创建如下格式的XML:

< sqls >
< sql  id ="insertProduct" >
  INSERT INTO product VALUES ('Sony Ericsson P990i') 
</ sql >
< sql  id ="queryProduct" >
  
<![CDATA[  SELECT title FROM product WHERE id=? AND insert_date > ? ]]>
</ sql >
</ sqls >

 

创建代码如下:

package  com.myyate.test.dom4j;

import  java.io.BufferedWriter;
import  java.io.File;
import  java.io.FileWriter;
import  java.io.Writer;

import  org.dom4j.CDATA;
import  org.dom4j.Document;
import  org.dom4j.DocumentHelper;
import  org.dom4j.Element;
import  org.dom4j.io.OutputFormat;
import  org.dom4j.io.XMLWriter;

public   class  SqlCreator  {

    
public SqlCreator() {
    document 
= DocumentHelper.createDocument();
    }

    
    
public void createSqlXmlFile(Writer xmlOut) throws Exception {
    Element root 
= document.addElement("sqls");
    
    Element sqlEle 
= DocumentHelper.createElement("sql");
    sqlEle.addAttribute(
"id""insertProduct");
    sqlEle.setText(
"INSERT INTO product VALUES ('Sony Ericsson P990i')");
    root.add(sqlEle);
    
    sqlEle 
= DocumentHelper.createElement("sql");
    sqlEle.addAttribute(
"id""queryProduct");
    CDATA sqlStr 
= 
        DocumentHelper.createCDATA(
"SELECT title FROM product WHERE id=? AND insert_date > ?");
    sqlEle.add(sqlStr);
    root.add(sqlEle);
    
//添加文档类型说明
    
//document.addDocType("sqls", "myyate", "*.dtd");    //name publicId systemId
    
//输出文档,并格式化输出
    XMLWriter out = new XMLWriter(xmlOut, OutputFormat.createPrettyPrint());
    out.write(document);
    out.close();
    }

    
    
static Writer getOutWriter() throws Exception {
    File outFile 
= new File("E:/project/designpattern/src/com/myyate/test/dom4j/sqls.xml");
    
if(!outFile.exists()) {
        outFile.createNewFile();
    }

    
    
return new FileWriter(outFile);
    }

    
    
public static void main(String[] args) throws Exception {
    SqlCreator sqlCreator 
= new SqlCreator();
    Writer xmlOut 
= new BufferedWriter(getOutWriter());
    sqlCreator.createSqlXmlFile(xmlOut);
    }

    
private Document document;
}

 

使用dom4j读取xml的代码如下:

package  com.myyate.test.dom4j;

import  java.io.InputStream;
import  java.util.HashMap;
import  java.util.List;
import  java.util.Map;

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

public   class  SqlReader  {

    
public SqlReader() throws Exception {
    read();
    }


    
public Map<String, String> parseSqlXmlFile() throws Exception {
    Map
<String, String> result = new HashMap<String, String>();

    List nodes 
= document.selectNodes("//sql");
    
if (nodes != null && !nodes.isEmpty()) {
        
for (Object obj : nodes) {
        Element sqlEle 
= (Element) obj;
        String id 
= sqlEle.attributeValue("id");
        String text 
= sqlEle.getText();
        result.put(id, text);
        }

    }


    
return result;
    }


    
private void read() throws Exception {
    SAXReader saxReader 
= new SAXReader();
    InputStream in 
= getClass().getResourceAsStream("sqls.xml");
    saxReader.setValidation(
false);
    document 
= saxReader.read(in);
    }


    
public static void main(String[] args) throws Exception {
    SqlReader sqlReader 
= new SqlReader();
    System.out.println(sqlReader.parseSqlXmlFile());
    }


    
private Document document;
}

 

这儿用xpath访问节点,要用到jaxen包,更多XPath访问的方式请看:XPath语法 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值