<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

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 国产99在线|亚洲| 亚洲资源在线视频| 老司机亚洲精品影院在线观看| 久久w5ww成w人免费| 中文亚洲AV片不卡在线观看| 产传媒61国产免费| 免费二级毛片免费完整视频| 国产偷国产偷亚洲高清人| 国产嫩草影院精品免费网址| 黄色免费网址在线观看| 久久99亚洲综合精品首页 | 91短视频免费在线观看| 亚洲人成影院在线高清| 毛片免费全部免费观看| 免费亚洲视频在线观看| AV在线播放日韩亚洲欧| 久久er国产精品免费观看2| 久久精品亚洲中文字幕无码麻豆 | 久久国产精品免费专区| 亚洲神级电影国语版| 成人av免费电影| 一级毛片a免费播放王色电影 | 激情内射亚洲一区二区三区爱妻| 亚洲免费综合色在线视频| 在线观看亚洲免费| 亚洲区小说区激情区图片区| 在线观看免费中文视频| 亚洲精品久久无码| 中文字幕亚洲综合久久男男| 久久精品无码专区免费青青 | 无码精品人妻一区二区三区免费| 精品亚洲一区二区三区在线观看| 久久99国产乱子伦精品免费| 亚洲精品GV天堂无码男同| 91麻豆精品国产自产在线观看亚洲| 国产精品99久久免费观看| 中日韩亚洲人成无码网站| 综合亚洲伊人午夜网 | 亚洲AV综合色区无码一区| 在线免费视频一区| 中文字幕无线码免费人妻|