【前言】
璐小编在之前学习BS的时候接触过XML(请戳:【XML】基础知识初步认识),后来在项目中我们也会遇到XML的配置文件,现在学习Java又遇到对XML的文档内容进行解析。看来对于XML的认知是不断加深的过程~本篇简介XML解析的方式以及使用Jaxp对XML文档进行dom解析。
【XML解析】
对于XML解析方式,有DOM文档对象模型和SAX两种。前者是官方的规范,后者则是XML社区事实上的标准。根据它们各自的优缺点来斟酌使用哪种方式。现在已经有很多开发包来帮助我们对XML进行解析,比如sun公司的Jaxp,它由org.w3c.dom、 org.xml.sax、javax.xml 等开发包组成。也有后来从Jdom分支出去的团队开发的dom4j,dom4j在实践中使用较多,下篇博客会做简要介绍,看官不要错过~
【Jaxp对XML文档进行DOM解析】
在Jaxp和dom4j之间,前者是sun公司的标准,后者则是实际开发中比较常用的开发包。但是我们还是有必要了解一下官方的标准,所以下面分享使用dom方式对XML文档进行读取。(如看官对增删改代码有需要,小编后续更新)
❀使用dom方式,创建工厂,得到dom解析器,使用解析器解析文档这三个步骤是基础,在此基础上再写具体读取XML文档的哪些节点内容的代码。
import javax.xml.parsers.DocumentBuilderFactory; import org.junit.Test; import org.w3c.dom.Document; import org.w3c.dom.Node; import org.w3c.dom.NodeList; //dom方式对XML文档进行CRUD public class Demo3 { //读取XML文档 <书名>Java开发</书名> 节点的值 @Test public void read1() throws Exception{ //1.创建工厂 DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance(); //2.得到dom解析器 DocumentBuilder builder=factory.newDocumentBuilder(); //3.解析XML文档,得到代表文档的Document Document document=builder.parse("src/book.xml"); //得到标签的节点 NodeList list=document.getElementsByTagName("书名"); Node node = list.item(1); //读取节点的值 String content=node.getTextContent(); System.out.println(content); } }
运行结果就是你所要读取的节点书名的值。小编使用Junit运行,结果值就是书名,此处不再贴图~