DDR爱好者之家 Design By 杰米

本文实例讲述了JSP针对XML文件操作技巧。分享给大家供大家参考,具体如下:

XML(Extensible Markup   Language)可扩展标记语言,这个基础知识在早些已经学习过。而这篇教程为什么把它放在J2EE下边呢,因为他也是J2EE的13规范之一,虽然XML是W3C万维网组织联盟指定的,并做了规范,所以说也是一种规范,我们也必须按照规范来,和JDBC,Servlet,Jsp,Ejb等一样的。

前边的文章已经介绍了XML的一些基础知识,主要是用来存储,传输数据的,但是这些数据我们怎么得到呢,也就是说怎么来解析XML呢?这里总结一下。

首先解析XML文件一般有两种方式:DOM解析和SAX解析,首先看一下两者的概念和基础知识:

一,原理:

DOM解析:在程序开始执行的时候,先将整个XML文件加载到内存中,在内存中形成一棵DOM树,然后通过某种编程语言对这颗树上的任意节点进行增删改查操作。
SAX解析:基于事件驱动型的解析方式。解析是有顺序的,顺序遵守:从左到右,从上到下。
基于事件驱动型的解析方式不需要将XML文件全部加载到内存中,所以这种方式不会耗费大量的内存,
只不过解析过去的节点不能再次解析,不够灵活,如果还想解析,只能再次从XML文件头开始。

二,两者的优缺点:

DOM解析:优点:灵活。因为整个树都在内存中,我们随时随地都可以对某个节点操作,解析过去的节点还可以再次解析,比较灵活。

缺点:如果XML文件很大,则会耗费大量的内存,因为这个XML文件很大,而需要访问
的节点又很少。
总结: 所以XML文件较小、需要解析的节点较多,这样才值得使用DOM解析。

SAX解析:优点:不会耗费大量的内存。
缺点:不灵活(我们可以使用另外一个技术XPATH,使用它可以在XML文件中快速定位要
解析的节点)。
总结:有了XPath技术,SAX解析方式成为我们常用的。

三,在JAVA中,java的JDK提供了关于XML的解析:org.w3c.dom.*,这是SUN对w3c规范的实现。但是效率,不够高。所以我们经常使用第三方组件,例如dom4j等,效率相对来说较高一些。

四,好,我们来看一下实例吧:

1,利用JAVA中的JDK提供的,来进行解析读XML文件:来看两篇博客写的很详细的:Java Dom解析,Java Sax解析。

2,这里写一下,利用dom4j的解析方法,其实很相同,只不过我感觉dom4j的方法名,属性名可能更容易使用:

a, 读XML文件(以下是基于SAX解析方式):

public static void main(String[] args) throws Exception{ 
    //创建SAX解析器对象 
    SAXReader reader = new SAXReader(); 
    //读取XML文件 
    Document document = reader.read(new File("db-config.xml")); 
    //获取根元素 
    Element rootElement = document.getRootElement(); 
    System.out.println("根节点的名字:" + rootElement.getName()); 
    //获取根节点下的子节点driver 
    Element driverElement = rootElement.element("driver"); 
    String driver = driverElement.getText(); 
    System.out.println(driver); 
    //获取根节点下的子节点url 
    String url = rootElement.elementText("url"); 
    System.out.println(url); 
    //获取根节点下的子节点user 
    String user = rootElement.elementText("user"); 
    System.out.println(user); 
    //获取根节点下的子节点password 
    String password = rootElement.elementText("password"); 
    System.out.println(password); 
} 

b,写文件,就是从上向下的了,我们dom4j中的DOM解析的方式:

public static void main(String[] args) throws Exception{ 
    //在内存中先创建一个文档对象 
    Document document = DocumentHelper.createDocument(); 
    //构造文档树 
    Element stuInfoElement = document.addElement("数学专业书籍"); 
    Element stuElement1 = stuInfoElement.addElement("书"); 
    stuElement1.addAttribute("id", "110"); 
    Element nameElement1 = stuElement1.addElement("书名"); 
    nameElement1.setText("近世代数"); 
    Element stuElement2 = stuInfoElement.addElement("书"); 
    stuElement2.addAttribute("id", "120"); 
    Element nameElement2 = stuElement2.addElement("书名"); 
    nameElement2.setText("高等代数"); 
    //设置字符编码方式 
    OutputFormat format = OutputFormat.createPrettyPrint(); 
    format.setEncoding("GB18030"); 
    //开始写入 
    XMLWriter xmlWriter = new XMLWriter(new FileWriter("students.xml"),format); 
    xmlWriter.write(document); 
    xmlWriter.close(); 
} 

最后写成的文件:

<"1.0" encoding="GB18030""110"> 
    <书名>张三</书名> 
  </书> 
 <书 id="110"> 
    <书名>张三</书名> 
  </书> 
 </数学专业书籍> 

综上,为XML解析的简单总结,当然实际中会遇到非常复杂的XML文件,我们可以自己来试着写这些解析他们的文件,当然也可以使用人家写好的,这里只是为了多学习,理解它们的本质。

希望本文所述对大家JSP程序设计有所帮助。

DDR爱好者之家 Design By 杰米
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
DDR爱好者之家 Design By 杰米

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。