一、首先了解一些基本的概念:
1.JAXP
Java的XML解析API
2.DOM
Document Object Model的缩写,意思是文档对象模型(又叫节点模型、树模型),它的作用在于首先将XML文件加载到内存,再任意的读取;所有它的优点是可以修改,方便灵活的读取,缺点是消耗内存。
3.SAX
简单XML的API,基于事件模型,事件流程是:读文档->-循环(读节点->读节点内容->结束读节点)->结束读节点;这样做的优点是可以读取大的XML,节约内存;缺点是不能修改,并且必须按照顺序读取。基于SAX,出现了DOM4j和JDOM两个优秀的API。
1.JDOM
将DOM和SAX的功能结合在一起,大大的简化了DOM和SAX;但是JDOM直接为JAVA服务,不够灵活,并且如果文档超出10M,就会出现内存溢出现象。
2.DOM4J
由于使用了大量接口,所以比JDOM灵活;完全支持JAXP、DOM、SAX,性能更加优异,Hibernate中解析XML使用的也是DOM4J。
二、使用DOM4J读写XML文档
1.写XML文档
package p1;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
public class Test3 {
public static void main(String[] args) throws Exception {
//创建文档
Document doc = DocumentHelper.createDocument();
//保存文档
String fileName = "文件名";
OutputStreamWriter outWriter = new OutputStreamWriter(
new FileOutputStream(fileName),"UTF-8");
//创建有缩进的格式对象
OutputFormat format = OutputFormat.createPrettyPrint();
//连接输出流和格式对象,得到字符流打印机
XMLWriter writer = new XMLWriter(outWriter,format);
//添加根节点
doc.addElement("节点名");
//添加子节点,节点名.addElement("节点名");
//添加文本,节点名.addText("文本");
//添加属性,节点名.addAttribute(键,值);
//写入流
writer.write(doc);
//关闭流
writer.close();
}
}
2.读XML文档
package p1;
import java.io.File;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class Test4 {
public static void main(String[] args) throws Exception {
//读取XML文档到Document对象
SAXReader reader = new SAXReader();
//设置读取格式
reader.setEncoding("UTF-8");
//设置读取文件路径
String fileName = "XXX.xml";
//创建文档对象
Document doc = reader.read(new File(fileName));
//获得根节点
Element ele = doc.getRootElement();
//获得一个子节点,父节点.Element("子节点名");
//获得对个子节点,父节点.Element("子节点");
//获得节点的父节点,节点.getParent();
//获得当前节点名,节点.getName();
//获得当前节点文本,节点.getText();
//获得子节点文本,节点.ElementText("子节点名");
//获得当前节点属性值,节点.valueOf("@属性名")或者节点.attributeValue("属性名");
}
}