首页(162) xml(5) spring(1) 生活(8) java(70) 代码(10) 英语(4) 数据库(7) c#(14) 成长(10) 软件工程(27)  写新日志
 
 

玻璃杯中的花生壳

  真爱的事业和真正的爱情一生只有一次,都值得我们温柔地相待,因为那种感觉是永远都无法复制的, 这世界真正属于你的东西其实并不多,你不好好珍惜,它便会离你而去,包括机遇,包括爱情,包括生命。
   不要找任何理由,  当幸福在你身边的时候就抓住它,你就一定会很幸福! 
   

时 间 记 忆
«October 2025»
1234
567891011
12131415161718
19202122232425
262728293031

最 新 评 论
回复:xml的Jdom解析过程详解
回复:突然想到的几句话!
 Boyle came out of n
回复:xml的Jdom解析过程详解
回复:配置Spring数据源
回复:使用SAX解析XML
回复:java中写文件操作时FileOu
回复:关联和依赖关系的区分
回复:HttpSessionListen
回复:Spring AOP四种创建通知(

最 新 日 志
Java开发者的十大戒律
配置Spring数据源
java多线程设计模式
java中switch的使用
性格,编码,测试
突然想到的几句话!
理解Spring AOP中的关键概念
Spring AOP四种创建通知(拦截器
xml的四种解析方法 比较 sax,do
xml的Jdom解析过程详解

最 新 留 言
签写新留言

我渴望知识
很好的东东
帖子不错,道声谢
想拜师学艺
我的呼喊

搜 索


用 户 登 录
用户名称:
登陆密码:
密码保存:

友 情 连 接

模板设计:部落窝模板世界

blog名称:玻璃杯中的花生壳
日志总数:162
评论数量:249
留言数量:1
访问次数:830328
建立时间:2004年11月4日
 
 
 
[xml]使用SAX解析XML
[ 2007/6/20 14:39:01 | By: 玻璃杯中的花生壳 ]
 
                        使用SAX解析XML 一、        前言 用Java解析XML文档,最常用的有两种方法:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object Module)称为DOM。Sun公司提供了Java API for XML Parsing(JAXP)接口来使用SAX和DOM,通过JAXP,我们可以使用任何与JAXP兼容的XML解析器。 JAXP接口包含了三个包: (1)       org.w3c.dom  W3C推荐的用于XML标准规划文档对象模型的接口。 (2)       org.xml.sax   用于对XML进行语法分析的事件驱动的XML简单API(SAX) (3)       javax.xml.parsers解析器工厂工具,程序员获得并配置特殊的特殊语法分析器。 二、        前提 DOM编程不要其它的依赖包,因为JDK里自带的JDK里含有的上面提到的org.w3c.dom、org.xml.sax 和javax.xml.parsers包就可以满意条件了。 三、        使用SAX解析XML文档 SAX是基于事件的简单API,同样的我们也是用一个最简单的例子来看看SAX是如何解析XML的 先来看看我们要解析的XML代码吧 <?xml version="1.0" encoding="gb2312"?> <books>   <book email="zhoujunhui">              <name addr="address">rjzjh</name>              <price>jjjjjj</price>   </book> </books> 简单的不能再简单了。但是该有的都有了,根元素、属性、子节点。好了,能反应问题就行了,下面来看看解析这个XML文件的Java代码吧! 1 public class SaxParse { 2     public SaxParse(){ 3            SAXParserFactory saxfac=SAXParserFactory.newInstance(); 4            try { 5                   SAXParser saxparser=saxfac.newSAXParser(); 6                   InputStream is=new FileInputStream("bin/library.xml"); 7                   saxparser.parse(is,new MySAXHandler()); 8            } catch (ParserConfigurationException e) { 9                   e.printStackTrace(); 10           } catch (SAXException e) { 11                  e.printStackTrace(); 12           } catch (FileNotFoundException e) { 13                  e.printStackTrace(); 14           } catch (IOException e) { 15                  e.printStackTrace(); 16           } 17    } 18    public static void main(String[] args) { 19           new SaxParse(); 20    } 21  } 这段代码比较短,因为SAX是事件驱动的,它的大部分实现在在另一个Java文件中,先别管另一个文件,我们来一个个地分析吧! (1)得到SAX解析器的工厂实例 3            SAXParserFactory saxfac=SAXParserFactory.newInstance(); 这是一个javax.xml.parsers.SAXParserFactory类的实例 (2)从SAX工厂实例中获得SAX解析器 5            SAXParser saxparser=saxfac.newSAXParser(); 使用javax.xml.parsers.SAXParserFactory工厂的newSAXParser()方法 (3)把要解析的XML文档转化为输入流,以便DOM解析器解析它 6                   InputStream is=new FileInputStream("bin/library.xml"); InputStream是一个接口。 (4)解析XML文档 7                   saxparser.parse(is,new MySAXHandler()); 后面就不用看了,都是些没用的代码(相对而言),够简单的吧! 注意了,我们新建了一个实例new MySAXHandler()这个实例里面又有什么东西呢? 这个实例就是SAX的精华所在。我们使用SAX解析器时,必须实现内容处理器ContentHandler接口中的一些回调方法,然而我们不须要全部地实现这些方法,还好,我们有org.xml.sax.helpers.DefaultHandler类,看它的类申明: public class DefaultHandler implements EntityResolver, DTDHandler, ContentHandler, ErrorHandler 实现了这么多接口啊,其它的先不管了,至少它实现了ContentHandler这一接口。 好了,看看这个类有些什么吧?下面是它的Java代码! public class MySAXHandler extends DefaultHandler {        boolean hasAttribute=false;        Attributes attributes=null;        /* (非 Javadoc)         * @see org.xml.sax.helpers.DefaultHandler#startDocument()         */        public void startDocument() throws SAXException {                System.out.println("文档开始打印了");        }        /* (非 Javadoc)         * @see org.xml.sax.helpers.DefaultHandler#endDocument()         */        public void endDocument() throws SAXException {               System.out.println("文档打印结束了");        }        /* (非 Javadoc)         * @see org.xml.sax.helpers.DefaultHandler#startElement(java.lang.String, java.lang.String, java.lang.String, org.xml.sax.Attributes)         */        public void startElement(String uri, String localName, String qName,                      Attributes attributes) throws SAXException {               if(qName.equals("books")){                      return;               }               if(qName.equals("book")){                      System.out.println(attributes.getQName(0)+attributes.getValue(0));               }               if(attributes.getLength()>0){                      this.attributes=attributes;                      this.hasAttribute=true;               }        }        /* (非 Javadoc)         * @see org.xml.sax.helpers.DefaultHandler#endElement(java.lang.String, java.lang.String, java.lang.String)         */        public void endElement(String uri, String localName, String qName)                      throws SAXException {               if(hasAttribute&&(attributes!=null)){                      for(int i=0;i<attributes.getLength();i++){                             System.out.println(attributes.getQName(0)+attributes.getValue(0));                      }               }        }        /* (非 Javadoc)         * @see org.xml.sax.helpers.DefaultHandler#characters(char[], int, int)         */        public void characters(char[] ch, int start, int length)                      throws SAXException {               System.out.println(new String(ch,start,length));        }     } 不要看它一大堆,我一一分解给大家看。我们说SAX是基于事件的API,我们这个类实到了ContentHandler接口中的如下方法: (1)startDocument()  用于处理文档解析开始事件      public void startDocument() throws SAXException {                System.out.println("文档开始打印了");         } (2)endDocument()  用于处理文档解析结束事件       public void endDocument() throws SAXException {               System.out.println("文档打印结束了");         } (3)startElement  用于处理元素开始事件      public void startElement(String uri, String localName, String qName,                      Attributes attributes) throws SAXException {               if(qName.equals("books")){                      return;               }               if(qName.equals("book")){                      System.out.println(attributes.getQName(0)+attributes.getValue(0));               }               if(attributes.getLength()>0){                      this.attributes=attributes;                      this.hasAttribute=true;               }        } 第二个参数String qName表示这个元素的名字,如: 根节点  <books></books>  它的
 

阅读全文(5861) | 回复(1) | 编辑 | 精华
 
 
回复:使用SAX解析XML
[ 2008/12/11 15:05:07 | By: jiafang83(游客) ]
 
太好啦,终于找到一篇详细介绍sax的文章啦!不过怎么没下文了呢?
 

个人主页 | 引用回复 | 主人回复 | 返回 | 编辑 | 删除
 
» 1 »

发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)
 
部落窝Blog模板世界部落窝Blog模板世界
站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 1.207 second(s), page refreshed 144795744 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号