首页 > 其他 > 详细

J2EE——XML

时间:2014-02-13 15:25:39      阅读:444      评论:0      收藏:0      [点我收藏+]

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


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


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

            一,原理:

             DOM解析:在程序开始执行的时候,先将整个XML文件加载到内存中,在内存中形成一棵DOM树,然后通过某种编程语言对这颗树上的任意节点进行增删改查操作。

              SAX解析:基于事件驱动型的解析方式。解析是有顺序的,顺序遵守:从左到右,从上到下。

基于事件驱动型的解析方式不需要将XML文件全部加载到内存中,所以这种方式不会耗费大量的内存,

只不过解析过去的节点不能再次解析,不够灵活,如果还想解析,只能再次从XML文件头开始。


           二,两者的优缺点:

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

                                                去的节点还可以再次解析,比较灵活。

                            缺点:如果XML文件很大,则会耗费大量的内存,因为这个XML文件很大,而需要访问

                                       的节点又很少。

    总结: 所以XML文件较小、需要解析的节点较多,这样才值得使用DOM解析。


  SAX解析:优点:不会耗费大量的内存。

              缺点:不灵活(我们可以使用另外一个技术XPATH,使用它可以在XML文件中快速定位要

                           解析的节点)

    总结:有了XPath技术,SAX解析方式成为我们常用的。


          三,在JAVA中,javaJDK提供了关于XML的解析:org.w3c.dom.*,这是SUNw3c规范的实现。但是效率,不够高。所以我们经常使用第三方组件,例如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文件,我们可以自己来试着写这些解析他们的文件,当然也可以使用人家写好的,这里只是为了多学习,理解它们的本质。


J2EE——XML

原文:http://blog.csdn.net/liujiahan629629/article/details/19135353

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!