posts - 92,  comments - 299,  trackbacks - 0

          隨著互聯網技術的發展,XML技術變得越來越重要,從而出現了很多
          與XML的整合應用方面的技術,SAX就是其中之一。在這里,我就簡要
          談談java怎樣使用sax對xml文檔的解析。

          首先,讓我們來談談SAX對XML文檔的解析機制。一般情況下,SAX 處理器
          分析XML代碼將生成以下事件:


          Start document
          Start element ()
          Characters (white space)
          Start element ()
          Characters ()
          End element ()
          ............
          End element ()

          具體解析步驟如下
          一、 創建事件處理程序,SAX 提供應用程序可擴展的類 DefaultHandler。
          創建的解析類config必須繼承類 DefaultHandler。
          如:public class Config extends DefaultHandler{}
          二、使用 JAXP 來創建解析器:使用 JAXP 中的類 XMLReaderFactory
          來創建解析器。首先聲明 XMLReader的一個對象 parser。然后使用
          XMLReaderFactory的createXMLReader方法來創建 SAXParser。
          XMLReader parser =
          XMLReaderFactory.createXMLReader(
          "org.apache.xerces.parsers.SAXParser");
          三、一旦創建了解析器,則需要將 config 設置為內容處理程序,
          以便于其接收事件。
          parser.setContentHandler(this);

          但是,當然總會有可能在試圖進行解析時,數據有問題。這時應該創建
          ErrorHandler 在這樣的情況下,有一個處理程序來處理錯誤和內容。
          parser.setErrorHandler(this);
          四、準備對文件進行實際解析。應用程序文件傳遞給 parse(),然后應用程序
          會繼續運行。
          parser.parse(confFile);
          五、接下來就開始對文檔進行解析了。前面說過SAX的處理機制,SAX在處理XML流
          的過程中,首先產生startDocument()事件,實際上該事件什么也沒有發生,因為
          還沒有定義任何解析的事件。使用 startDocument() 事件只是為了通知文檔的開
          始。類似其它 SAX 事件,該事件拋出 SAXException。
          例如:
          public void startDocument()
          throws SAXException {
          System.out.println(
          "Tallying survey results...");
          }

          六、跟下來,就正式開始對文件進行解析了。這時SAX會產生一個startElement()
          事件,對于每個元素,都會回送一個傳遞給 startElement() 事件的名稱。不過
          解析器實際所傳遞是:該元素的名稱空間信息;該元素的實際名稱或 localName;
          名稱空間別名和 localName 的組合(否則是限定名或 qname);以及該元素任何
          屬性。startElement() 事件還提供對元素屬性的訪問。將這些屬性傳遞進稱為
          Attributes的數據結構。根據屬性在數組中位置或屬性的名稱,可以檢索該屬性值。
          例如:
          public void startElement(
          String namespaceURI,
          String localName,
          String qName,
          Attributes atts)
          throws SAXException {
          String s = (!"".equals(localName)) ? localName : qName;

          System.out.print("Start element: ");
          System.out.println(localName);
          tag = s;
          if (localName == "Connector") {
          System.out.println("name: "
          + atts.getValue("name"));
          } else if (localName == "port") {
          thisQuestion = atts.getValue("servername");
          }else if (localName == "maxThreadPoolSize") {
          thisQuestion = atts.getValue("poolname");
          }
          if (localName == "Database") {
          System.out.println("name: "
          + atts.getValue("name"));
          } else if (localName == "driverName") {
          thisQuestion = atts.getValue("dataname");
          }else if (localName == "encoding") {
          thisQuestion = atts.getValue("codename");
          }
          thisElement = localName;


          for (int att = 0;att < atts.getLength(); att++) {
          String attName = atts.getLocalName(att);
          System.out.println(" "
          + attName + ": "
          + atts.getValue(attName));
          }


          }
          七、有了元素,接下來用 characters() 來檢索實際的數據。這時可以使用下面的
          方法獲得實際的數據:
          可以用String s = new String(ch, start, length).trim();
          這個方法來獲得數據。
          例如:
          public void characters(char[] ch,
          int start,
          int length)
          throws SAXException {

          String s = new String(ch, start, length).trim();
          if (!"".equals(s)) {
          if ("port".equals(tag)) {
          System.out.println(Integer.parseInt(s));
          } else if ("maxThreadPoolSize".equals(tag)) {
          System.out.println(Integer.parseInt(s));
          }
          //System.out.println(tag+" = "+s);
          }

          s = new String(ch, start, length).trim();
          if (!"".equals(s)) {
          if ("driverName".equals(tag)) {
          System.out.println(s);
          } else if ("encoding".equals(tag)) {
          System.out.println(s);
          }
          //System.out.println(tag+" = "+s);
          }
          }
          八、接下來的要做的就是用endElement()來結束對一個xml的 element的解析。
          例如:下面的方法
          public void endElement(String namespaceURI,
          String localName,
          String qName)
          throws SAXException {

          printIndent(indent);
          System.out.println("End Element: "+localName);
          indent = indent - 4;
          thisQuestion = "";
          thisElement = "";
          九、最后就是告訴程序,xml文件解析完畢,此時,用endDocument()來結束程序。
          例如:
          public void endDocument() {}

          總的來說,sax處理xml的方法還基本上是差不多的,只是一二步的方法相對多一點,
          那些其他的方法我這里就不多說了,由讀者自己去查找資料。

          [2年前寫的東西,可能有點過時了~~~]

          posted on 2005-03-08 15:43 coffee 閱讀(2047) 評論(1)  編輯  收藏

          FeedBack:
          # re: java使用sax對xml文檔的解析
          2005-05-17 09:37 | 王磊
          能不能講的更詳細一些,舉個例子,找一些源代碼看看,效果會更好!  回復  更多評論
            

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          <2005年3月>
          272812345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          棱而無角,圓而有方,我永遠的追求。

          常用鏈接

          留言簿(22)

          隨筆分類(103)

          隨筆檔案(93)

          文章分類(3)

          相冊

          收藏夾

          java

          其它

          最新隨筆

          搜索

          •  

          積分與排名

          • 積分 - 79120
          • 排名 - 708

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 冷水江市| 陵川县| 青铜峡市| 呼伦贝尔市| 和平县| 莱西市| 阿勒泰市| 江油市| 通州市| 城步| 伊金霍洛旗| 库尔勒市| 中阳县| 巴彦县| 莱芜市| 剑河县| 新田县| 西昌市| 丹凤县| 达日县| 元阳县| 清新县| 杭锦后旗| 南丰县| 张家口市| 深圳市| 安康市| 邵阳市| 望都县| 江川县| 平原县| 太白县| 二连浩特市| 靖江市| 宜昌市| 琼海市| 巍山| 天镇县| 仪征市| 南安市| 福州市|