【XML解析】使用Jaxp对XML进行DOM解析

【前言】

   璐小编在之前学习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运行,结果值就是书名,此处不再贴图~


【小结】

    对于同一个知识点的学习反复又一次深入,了解了不同的侧面,对一个点的认识也再不断的完善。下篇文章简述使用dom4j对XML文档的解析,尽请期待。
    本文如述偏颇,请看官评论指正,谢谢您的阅读~


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 25
    评论
评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值