XML之DOM解析
2016-12-25 本文已影响279人
Mr_欢先生
1.xml解析方式:
DOM解析原理:xml解析器将xml文件加载到内存,然后构建出一个Document的树状图,通过Document对象获得树上的节点对象,通过对节点的访问获得xml文档的内容。
1)JAXP 工具(oracle-sun公司官方)
2)JDOM工具(非官方)
3)Dom4J工具(非官方)--三大框架(默认读取的工具就是Dom4j)
Dom4J工具:
导入dom4j的核心包【下载地址 密码:9rh1】
SAX解析:
Sax 解析工具(oracle-sun公司官方)
2.搭建环境及演示:
新建Java项目 创建xml文件 写入内容XML文件内容:
<?xml version="1.0" encoding="UTF-8"?>
<contactList>
<contact id="1">
<name>某某</name>
<age>20</age>
<phone>15426354785</phone>
<qq>1024557455</qq>
</contact>
<contact id="2">
<name>张三</name>
<age>44</age>
<phone>17854213658</phone>
<qq>1024532584</qq>
</contact>
</contactList>
新建lib文件夹将dom4j-1.6.1.jar包导入
添加到构建路径
出现奶瓶标志表示导入成功
新建Java类
one.java代码如下:
package com.one;
import java.io.File;
import java.util.Iterator;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.Test;
public class damo {
@Test
public void texs() throws Exception{
//创建一个xml解析对象
SAXReader reader = new SAXReader();
//读取xml文档,返回Document对象
Document dor= reader.read(new File("./src/one.xml"));
//获取根节点
Element ele = dor.getRootElement();
//调用方法
getChildNode(ele);
}
private void getChildNode(Element elem){
System.out.println(elem.getName());
Iterator <Node> it= elem.nodeIterator();
while(it.hasNext()){
Node node = it.next();
if(node instanceof Element){
Element el = (Element)node;
//递归方法
getChildNode(el);
}
}
}
}
JUnit4方法
添加成功
获取到标签节点名称