java 解析web.xml_Java web xml文件读取解析方式

其实解析xml文件有四种方式:DOM,JDOM,DOM4J,SAX。

我们来说与平台无关的两种官方解析方式:DOM 和 SAX

一、DOM 解析

在 Java 代码中,xml 文件是标记型文档,这时用 dom 来解析 xml 文件 dom 会根据 html 的层级结构在内存中分配一个树形结构,把html的标签,属性和文本都封装成对象

DOM 解析步骤:

1、使用 newInstance 方法,创建一个 DocumentBuilderFactory 的对象。

2、创建一个 DocumentBuilde r对象,通过 DocumentBuilder 的对象的 parse[]

方法加载 xml 文件到当前项目下,如:

DocumentBuilder db=dbf.newDocumentBuilder();

Document document=db.parse(uri);

3、获取 xml 文件

NodeList booklist = document.getElementsByTagName(节点名称);

4、用foreach方法进行遍历

5、解析子节点

NodeList childnode=book.getChildNodes();可用childnode.item(k).getNodeType()==Node.ELEMENT_NODE这个方法进行判断以区分text类型的node以及element类型的node。

DOM 解析的优点:可以很方便实现增删改的功能

缺点:如果文件过大,造成内存溢出

二、SAX 解析

在 Java 中,SAX 解析采用事件驱动,边读边解析,从上到下,一行一行的解析,解析到某一个对象,返回对象名称。而且当SAX解析结束,不会保存任何XML文档的数据。

SAX 解析步骤:

1、创建一个 SAXParserFactory 对象。

SAXParserFactory factory = SAXParserFactory.newInstance();

2、创建一个 SAXParser 对象通过 parse 方法加载 xml 文件。

SAXParser parser = factory.newSAXParser();

这时与DOM的区别是这里需要一个 handler,此时需要创建一个 handler 类。

3、handler 类需要继承 DefaultHandler。

SAX 解析的优点:如果文件过大,不会造成内存溢出,方便实现查询操作;

缺点:不能实现增删改操作;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值