JSP针对XML文件操作技巧实例分析
本文实例讲述了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(); }
最后写成的文件:
<?xml version="1.0" encoding="gb18030"?> <数学专业书籍> <书 id="110"> <书名>张三</书名> </书> <书 id="110"> <书名>张三</书名> </书> </数学专业书籍>
综上,为xml解析的简单总结,当然实际中会遇到非常复杂的xml文件,我们可以自己来试着写这些解析他们的文件,当然也可以使用人家写好的,这里只是为了多学习,理解它们的本质。
希望本文所述对大家jsp程序设计有所帮助。
上一篇: jdbc的简单使用
推荐阅读
-
Python 文件操作技巧(File operation) 实例代码分析
-
JSP针对XML文件操作技巧实例分析
-
Python 文件操作技巧(File operation) 实例代码分析
-
JSP针对XML文件操作技巧实例分析
-
Python 文件操作技巧(File operation) 实例代码分析
-
Python 文件操作技巧(File operation) 实例代码分析
-
JS操作XML实例总结(加载与解析XML文件、字符串)_javascript技巧
-
JS操作XML实例总结(加载与解析XML文件、字符串)_javascript技巧
-
PHP针对JSON操作实例分析_php技巧
-
R语言操作XML文件实例分析