<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    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 閱讀(2041) 評論(1)  編輯  收藏

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

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


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

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

    常用鏈接

    留言簿(22)

    隨筆分類(103)

    隨筆檔案(93)

    文章分類(3)

    相冊

    收藏夾

    java

    其它

    最新隨筆

    搜索

    •  

    積分與排名

    • 積分 - 78730
    • 排名 - 708

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 国产精品久久久久久亚洲影视| 亚洲成人高清在线观看| 在线观看亚洲视频| 国产香蕉九九久久精品免费| 亚洲va成无码人在线观看| 99久久久国产精品免费牛牛四川| 亚洲精品线在线观看| 久久永久免费人妻精品| 久久夜色精品国产噜噜噜亚洲AV | 亚洲国产精品专区| 37pao成人国产永久免费视频| 亚洲视频在线观看视频| 黄色成人免费网站| 亚洲一区二区三区免费视频| 成人免费一区二区三区在线观看| 一区二区亚洲精品精华液| 国产成人涩涩涩视频在线观看免费| 免费观看亚洲人成网站| 久久久久亚洲爆乳少妇无| 美女在线视频观看影院免费天天看 | 亚洲一区二区三区香蕉| 久久国产精品2020免费m3u8| 亚洲国产成人精品无码区在线网站| 99精品国产免费久久久久久下载| 亚洲av无码专区在线电影| 亚洲成AV人在线观看网址| 久久久精品视频免费观看| 日本久久久久亚洲中字幕| 免费看黄视频网站| 免费无码午夜福利片69| 无码专区—VA亚洲V天堂| 成人超污免费网站在线看| 丁香六月婷婷精品免费观看| 久久久亚洲精品视频| 午夜成年女人毛片免费观看| 一级黄色免费毛片| 亚洲成a人片在线观看中文!!!| 永久免费bbbbbb视频| 久久久久国产精品免费网站| 亚洲精品无AMM毛片| 亚洲爆乳无码专区|