本文实例讲述了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程序设计有所帮助。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]