国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

Java web xml文件讀取解析方式

瀏覽:4日期:2022-09-04 16:24:21

其實解析xml文件有四種方式:DOM,JDOM,DOM4J,SAX。

我們來說與平臺無關(guān)的兩種官方解析方式:DOM 和 SAX

一、DOM 解析

在 Java 代碼中,xml 文件是標(biāo)記型文檔,這時用 dom 來解析 xml 文件 dom 會根據(jù) html 的層級結(jié)構(gòu)在內(nèi)存中分配一個樹形結(jié)構(gòu),把html的標(biāo)簽,屬性和文本都封裝成對象

DOM 解析步驟:1、使用 newInstance 方法,創(chuàng)建一個 DocumentBuilderFactory 的對象。

2、創(chuàng)建一個 DocumentBuilde r對象,通過 DocumentBuilder 的對象的 parse[]

方法加載 xml 文件到當(dāng)前項目下,如:

DocumentBuilder db=dbf.newDocumentBuilder();

Document document=db.parse(uri);

3、獲取 xml 文件

NodeList booklist = document.getElementsByTagName(節(jié)點名稱);

4、用foreach方法進(jìn)行遍歷

5、解析子節(jié)點

NodeList childnode=book.getChildNodes();可用childnode.item(k).getNodeType()==Node.ELEMENT_NODE這個方法進(jìn)行判斷以區(qū)分text類型的node以及element類型的node。

DOM 解析的優(yōu)點:可以很方便實現(xiàn)增刪改的功能

缺點:如果文件過大,造成內(nèi)存溢出

二、SAX 解析

在 Java 中,SAX 解析采用事件驅(qū)動,邊讀邊解析,從上到下,一行一行的解析,解析到某一個對象,返回對象名稱。而且當(dāng)SAX解析結(jié)束,不會保存任何XML文檔的數(shù)據(jù)。

SAX 解析步驟:

1、創(chuàng)建一個 SAXParserFactory 對象。

SAXParserFactory factory = SAXParserFactory.newInstance();

2、創(chuàng)建一個 SAXParser 對象通過 parse 方法加載 xml 文件。

SAXParser parser = factory.newSAXParser();

這時與DOM的區(qū)別是這里需要一個 handler,此時需要創(chuàng)建一個 handler 類。

3、handler 類需要繼承 DefaultHandler。

SAX 解析的優(yōu)點:如果文件過大,不會造成內(nèi)存溢出,方便實現(xiàn)查詢操作;缺點:不能實現(xiàn)增刪改操作;

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 义马市| 巨野县| 遂昌县| 镶黄旗| 同江市| 怀化市| 宕昌县| 于都县| 玉门市| 云龙县| 惠州市| 额尔古纳市| 东辽县| 西贡区| 县级市| 新营市| 饶平县| 凌海市| 昌都县| 扶余县| 蒙自县| 溧水县| 贺兰县| 万源市| 思茅市| 册亨县| 格尔木市| 赣州市| 阜阳市| 西乌珠穆沁旗| 常宁市| 阿图什市| 深泽县| 青岛市| 卢湾区| 茂名市| 杭锦旗| 石柱| 新晃| 宣武区| 山东|