當前位置:首頁 » 編程語言 » javaxmlsax

javaxmlsax

發布時間: 2022-07-22 03:56:21

『壹』 java sax解析xml大文件報錯: 超出"FEATURE_SECURE_PROCESSING" 設置的 "50,000,000" 限制

szx解析xml文件,對文件的大小沒有限制,但是由於解析的過程是需要分配系統內存的,如果內存不夠,可能會造成內存溢出的系統異常。

『貳』 java的xml的解析方式有什麼,他們的解析流程是怎麼樣的,有什麼區別

答:4種。(或者說是兩種,因為JDOM和DOM4J是DOM的兩個特殊情況)

1.SAX解析
解析方式是事件驅動機制!

SAX解析器,逐行讀取XML文件解析,每當解析到一個標簽的開始/結束/內容/屬性時,觸發事件。

可以在這些事件發生時,編寫程序進行相應的處理。

優點:

分析能夠立即開始,而不是等待所有的數據被處理。

逐行載入,節省內存,有助於解析大於系統內存的文檔。

有時不必解析整個文檔,它可以在某個條件得到滿足時停止解析。

缺點:

1.單向解析,無法定位文檔層次,無法同時訪問同一個文檔的不同部分數據(因為逐行解析,當解析第n行時,第n-1行)已經被釋放了,無法再對其進行操作)。

2. 無法得知事件發生時元素的層次, 只能自己維護節點的父/子關系。

3. 只讀解析方式, 無法修改XML文檔的內容。

2. DOM解析
是用與平台和語言無關的方式表示XML文檔的官方W3C標准,分析該結構通常需要載入整個 文檔和內存中建立文檔樹模型。程序員可以通過操作文檔樹, 來完成數據的獲取 修改 刪除等。

優點:

文檔在內存中載入, 允許對數據和結構做出更改。訪問是雙向的,可以在任何時候在樹中雙向解析數據。

缺點:

文檔全部載入在內存中 , 消耗資源大。

3. JDOM解析
目的是成為Java特定文檔模型,它簡化與XML的交互並且比使用DOM實現更快。由於是第一 個Java特定模型,JDOM一直得到大力推廣和促進。

JDOM文檔聲明其目的是「使用20%(或更少)的精力解決80%(或更多)Java/XML問題」 (根據學習曲線假定為20%)

優點:

使用具體類而不是介面,簡化了DOM的API。

大量使用了Java集合類,方便了Java開發人員。

缺點:

沒有較好的靈活性。

性能不是那麼優異。

4. DOM4J解析
它是JDOM的一種智能分支。它合並了許多超出基本XML文檔表示的功能,包括集成的XPath 支持、XML Schema支持以及用於大文檔或流化文檔的基於事件的處理。它還提供了構建文檔表示的選項, DOM4J是一個非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一 個開放源代碼的軟體。如今你可以看到越來越多的Java軟體都在使用DOM4J來讀寫XML。

目前許多開源項目中大量採用DOM4J , 例如:Hibernate。

『叄』 目前在Java中幾種常用的XML解析器的比較

目前常用的XML的解析器主要有:SAX,DOM,Xerces

1、SAX處理的優點非常類似於流媒體的優點。分析能夠立即開始,而不是等待所有的數據被處理。而且,由於應用程序只是在讀取數據時檢查數據,因此不需要將數據存儲在內存中。這對於大型文檔來說是個巨大的優點。事實上,應用程序甚至不必解析整個文檔;它可以在某個條件得到滿足時停止解析。一般來說,SAX還比它的替代者DOM快許多。另一方面,由於應用程序沒有以任何方式存儲數據,使用SAX來更改數據或在數據流中往後移是不可能的。

2、DOM以及廣義的基於樹的處理具有幾個優點。首先,由於樹在內存中是持久的,因此可以修改它以便應用程序能對數據和結構作出更改。它還可以在任何時候在樹中上下導航,而不是像SAX那樣是一次性的處理。DOM使用起來也要簡單得多。另一方面,在內存中構造這樣的樹涉及大量的開銷。大型文件完全佔用系統內存容量的情況並不鮮見。此外,創建一棵DOM樹可能是一個緩慢的過程。

3、選擇DOM還是選擇SAX,這取決於下面幾個因素:
應用程序的目的:如果打算對數據作出更改並將它輸出為XML,那麼在大多數情況下,DOM是適當的選擇。並不是說使用SAX就不能更改數據,但是該過程要復雜得多,因為您必須對數據的一份拷貝而不是對數據本身作出更改。
數據容量:對於大型文件,SAX是更好的選擇。數據將如何使用:如果只有數據中的少量部分會被使用,那麼使用SAX來將該部分數據提取到應用程序中可能更好。另一方面,如果您知道自己以後會回頭引用已處理過的大量信息,那麼SAX也許不是恰當的選擇。
對速度的需要:SAX實現通常要比DOM實現更快。
SAX和DOM不是相互排斥的,記住這點很重要。您可以使用DOM來創建SAX事件流,也可以使用SAX來創建DOM樹。事實上,用於創建DOM樹的大多數解析器實際上都使用SAX來完成這個任務!

4、SAX,DOM是兩種對XML文檔進行分析的方法(沒有具體的實現,只有介面),所以不是解釋器,如果光有他們,你是完成不了對xml文檔的處理的。SAX的包是org.xml.sax,DOM的包是org.w3c.dom,包的名稱很重要,它有助於你理解他們之間的關系。

5、jaxp是api,他封裝了sax/dom兩種介面。並在sax/dom的基礎之上,作了一套比較簡單的api以供開發人員使用。jaxp的包是javax.xml.parsers,可以看看jaxp的源文件,它的文件中包含了對sax或者dom的引用(import)jaxp也不是具體的實現,他只是一套api。如果你僅僅有jaxp那是無法工作的,(其實jaxp只是完成對sax、dom的包裝,生成了DocumentBuilderFactory/DocumentBuilder和SAXParserFactorySAXParser。也就是設計模式中的工廠模式,他的好處就是具體的對象(解釋器)建立由子類完成)

6、xerces解釋器(號稱地球上最快的xml解釋器)在xerces中對jaxp中定義的進行了繼承(extends)對應ryImpl這就是為什麼你的classpath中只要有xerces.jar(其中包含了saxdomjaxp)和xercesImpl.jar就可以的原因了.

『肆』 java如何用sax創建和解析單標簽xml

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;

import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

/**
*
* SAX文檔解析
*
* @author bin 2013-11-18
*/
public class SaxDemoImpl {

public void createXml(String fileName) {
System.out.println("<<" + fileName + ">>");
}

public void parserXml(String fileName) {
SAXParserFactory saxfac = SAXParserFactory.newInstance();

try {

SAXParser saxparser = saxfac.newSAXParser();

InputStream is = new FileInputStream(fileName);

saxparser.parse(is, new MySAXHandler());

} catch (ParserConfigurationException e) {

e.printStackTrace();

} catch (SAXException e) {

e.printStackTrace();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

}

class MySAXHandler extends DefaultHandler {

boolean hasAttribute = false;

Attributes attributes = null;

public void startDocument() throws SAXException {

System.out.println("文檔開始列印了");

}

public void endDocument() throws SAXException {

System.out.println("文檔列印結束了");

}

public void startElement(String uri, String localName, String qName,

Attributes attributes) throws SAXException {

System.err.println(uri + " || " + localName + " || " + qName + " || " + attributes);
/*if (qName.equals("employees")) {

return;

}

if (qName.equals("employee")) {

System.out.println(qName);

}

if (attributes.getLength() > 0) {

this.attributes = attributes;

this.hasAttribute = true;

}*/

}

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.print(attributes.getQName(0) + " ssss "
+ attributes.getValue(0));

}

}

}

public void characters(char[] ch, int start, int length)

throws SAXException {

System.out.println(new String(ch, start, length));

}

『伍』 在java中解析xml有哪幾種方法

(1)DOM解析
DOM是html和xml的應用程序介面(API),以層次結構(類似於樹型)來組織節點和信息片段,映射XML文檔的結構,允許獲取
和操作文檔的任意部分,是W3C的官方標准
【優點】
①允許應用程序對數據和結構做出更改。
②訪問是雙向的,可以在任何時候在樹中上下導航,獲取和操作任意部分的數據。
【缺點】
①通常需要載入整個XML文檔來構造層次結構,消耗資源大。
【解析詳解】
①構建Document對象:
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = bdf.newDocumentBuilder();
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream(xml文件);
Document doc = bd.parse(is);
②遍歷DOM對象
Document: XML文檔對象,由解析器獲取
NodeList: 節點數組
Node: 節點(包括element、#text)
Element: 元素,可用於獲取屬性參數
(2)SAX(Simple API for XML)解析
流模型中的"推"模型分析方式。通過事件驅動,每發現一個節點就引發一個事件,事件推給事件處理器,通過回調方法
完成解析工作,解析XML文檔的邏輯需要應用程序完成
【優勢】
①不需要等待所有數據都被處理,分析就能立即開始。
②只在讀取數據時檢查數據,不需要保存在內存中。
③可以在某個條件得到滿足時停止解析,不必解析整個文檔。
④效率和性能較高,能解析大於系統內存的文檔。
【缺點】
①需要應用程序自己負責TAG的處理邏輯(例如維護父/子關系等),文檔越復雜程序就越復雜。
②單向導航,無法定位文檔層次,很難同時訪問同一文檔的不同部分數據,不支持XPath。
【原理】
簡單的說就是對文檔進行順序掃描,當掃描到文檔(document)開始與結束、元素(element)開始與結束時通知事件
處理函數(回調函數),進行相應處理,直到文檔結束
【事件處理器類型】
①訪問XML DTD:DTDHandler
②低級訪問解析錯誤:ErrorHandler
③訪問文檔內容:ContextHandler
【DefaultHandler類】
SAX事件處理程序的默認基類,實現了DTDHandler、ErrorHandler、ContextHandler和EntityResolver介面,通常
做法是,繼承該基類,重寫需要的方法,如startDocument()
【創建SAX解析器】
SAXParserFactory saxf = SAXParserFactory.newInstance();
SAXParser sax = saxf.newSAXParser();
註:關於遍歷
①深度優先遍歷(Depthi-First Traserval)
②廣度優先遍歷(Width-First Traserval)
(3)JDOM(Java-based Document Object Model)
Java特定的文檔對象模型。自身不包含解析器,使用SAX
【優點】
①使用具體類而不是介面,簡化了DOM的API。
②大量使用了Java集合類,方便了Java開發人員。
【缺點】
①沒有較好的靈活性。
②性能較差。
(4)DOM4J(Document Object Model for Java)
簡單易用,採用Java集合框架,並完全支持DOM、SAX和JAXP
【優點】
①大量使用了Java集合類,方便Java開發人員,同時提供一些提高性能的替代方法。
②支持XPath。
③有很好的性能。
【缺點】
①大量使用了介面,API較為復雜。
(5)StAX(Streaming API for XML)
流模型中的拉模型分析方式。提供基於指針和基於迭代器兩種方式的支持,JDK1.6新特性
【和推式解析相比的優點】
①在拉式解析中,事件是由解析應用產生的,因此拉式解析中向客戶端提供的是解析規則,而不是解析器。
②同推式解析相比,拉式解析的代碼更簡單,而且不用那麼多庫。
③拉式解析客戶端能夠一次讀取多個XML文件。
④拉式解析允許你過濾XML文件和跳過解析事件。
【簡介】
StAX API的實現是使用了Java Web服務開發(JWSDP)1.6,並結合了Sun Java流式XML分析器(SJSXP)-它位於
javax.xml.stream包中。XMLStreamReader介面用於分析一個XML文檔,而XMLStreamWriter介面用於生成一個
XML文檔。XMLEventReader負責使用一個對象事件迭代子分析XML事件-這與XMLStreamReader所使用的游標機制
形成對照。

『陸』 java解析xml的幾種方式哪種最好

在java中解析xml有哪幾種方法?
1、JDOM生成和解析XML
為減少DOM、SAX的編碼量,出現了JDOM
優點:20-80原則,極大減少了代碼量。
使用場合:要實現的功能簡單,如解析、創建等,但在底層,JDOM還是使用SAX(最常用)、DOM、Xanan文檔。
2、SAX生成和解析XML文檔
為解決DOM的問題,出現了SAX,SAX
事件驅動。當解析器發現元素開始、元素結束、文本、文檔的開始或結束等時發送事件,程序員編寫響應這些事件的代碼,保存數據。
優點:不用事先調入整個文檔,佔用資源少。SAX解析器代碼比DOM解析器代碼小,適於Applet下載。
缺點:不是持久的,事件過後若沒保存數據,那麼數據就丟了。無狀態性,從事件中只能得到文本,但不知該文本屬於哪個元素。
使用場合:Applet。只需XML文檔的少量內容,很少回頭訪問,機器內存少。
3、DOM生成和解析XML文檔
為XML文檔的已解析版本定義了一組介面。解析器讀入整個文檔,然後構建一個駐留內存的樹結構,然後代碼就可以使用 DOM 介面來操作這個樹結構。
優點:整個文檔樹在內存中,便於操作,支持刪除、修改、重新排列等多種功能。
缺點:將整個文檔調入內存(包括無用的節點),浪費時間和空間。
使用場合:一旦解析了文檔還需多次訪問這些數據,硬體資源充足(內存、CPU)。

『柒』 java解析xml有幾種方法

SAX, DOM, jdom , dom4j四種

1、DOM(JAXP Crimson解析器)

DOM是用與平台和語言無關的方式表示XML文檔的官方W3C標准。DOM是以層次結構組織的節點或信息片斷的集合。

這個層次結構允許開發人員在樹中尋找特定信息。分析該結構通常需要載入整個文檔和構造層次結構,然後才能做任何工作。

由於它是基於信息層次的,因而DOM被認為是基於樹或基於對象的。DOM以及廣義的基於樹的處理具有幾個優點。

首先,由於樹在內存中是持久的,因此可以修改它以便應用程序能對數據和結構作出更改。

它還可以在任何時候在樹中上下導航,而不是像SAX那樣是一次性的處理。DOM使用起來也要簡單得多。

2、SAX

SAX處理的優點非常類似於流媒體的優點。分析能夠立即開始,而不是等待所有的數據被處理。而且,由於應用程序只是在讀取數據時檢查數據,因此不需要將數據存儲在內存中。這對於大型文檔來說是個巨大的優點。事實上,應用程序甚至不必解析整個文檔;它可以在某個條件得到滿足時停止解析。一般來說,SAX還比它的替代者DOM快許多。 選擇DOM還是選擇SAX? 對於需要自己編寫代碼來處理XML文檔的開發人員來說,選擇DOM還是SAX解析模型是一個非常重要的設計決策。 DOM採用建立樹形結構的方式訪問XML文檔,而SAX採用的事件模型。

DOM解析器把XML文檔轉化為一個包含其內容的樹,並可以對樹進行遍歷。用DOM解析模型的優點是編程容易,開發人員只需要調用建樹的指令,然後利用navigation APIs訪問所需的樹節點來完成任務。可以很容易的添加和修改樹中的元素。然而由於使用DOM解析器的時候需要處理整個XML文檔,所以對性能和內存的要求比較高,尤其是遇到很大的XML文件的時候。由於它的遍歷能力,DOM解析器常用於XML文檔需要頻繁的改變的服務中。

SAX解析器採用了基於事件的模型,它在解析XML文檔的時候可以觸發一系列的事件,當發現給定的tag的時候,它可以激活一個回調方法,
告訴該方法制定的標簽已經找到。SAX對內存的要求通常會比較低,因為它讓開發人員自己來決定所要處理的tag。
特別是當開發人員只需要處理文檔中所包含的部分數據時,SAX這種擴展能力得到了更好的體現。但用SAX解析器的時候編碼工作會比較困難,
而且很難同時訪問同一個文檔中的多處不同數據。

3、JDOM

JDOM的目的是成為Java特定文檔模型,它簡化與XML的交互並且比使用DOM實現更快。由於是第一個Java特定模型,JDOM一直得到大力推廣和促進。

正在考慮通過「Java規范請求JSR-102」將它最終用作「Java標准擴展」。從2000年初就已經開始了JDOM開發。

JDOM與DOM主要有兩方面不同。首先,JDOM僅使用具體類而不使用介面。這在某些方面簡化了API,但是也限制了靈活性。

第二,API大量使用了Collections類,簡化了那些已經熟悉這些類的Java開發者的使用。

JDOM文檔聲明其目的是「使用20%(或更少)的精力解決80%(或更多)Java/XML問題」(根據學習曲線假定為20%)。JDOM對於大多數Java/XML應用程序來說當然是有用的,並且大多數開發者發現API比DOM容易理解得多。JDOM還包括對程序行為的相當廣泛檢查以防止用戶做任何在XML中無意義的事。

然而,它仍需要您充分理解XML以便做一些超出基本的工作(或者甚至理解某些情況下的錯誤)。這也許是比學習DOM或JDOM介面都更有意義的工作。

JDOM自身不包含解析器。它通常使用SAX2解析器來解析和驗證輸入XML文檔(盡管它還可以將以前構造的DOM表示作為輸入)。

它包含一些轉換器以將JDOM表示輸出成SAX2事件流、DOM模型或XML文本文檔。JDOM是在Apache許可證變體下發布的開放源碼

4、DOM4J

雖然DOM4J代表了完全獨立的開發結果,但最初,它是JDOM的一種智能分支。它合並了許多超出基本XML文檔表示的功能,包括集成的XPath支持、XML Schema支持以及用於大文檔或流化文檔的基於事件的處理。它還提供了構建文檔表示的選項,它通過DOM4J API和標准DOM介面具有並行訪問功能。從2000下半年開始,它就一直處於開發之中。

為支持所有這些功能,DOM4J使用介面和抽象基本類方法。DOM4J大量使用了API中的Collections類,但是在許多情況下,它還提供一些替代方法以允許更好的性能或更直接的編碼方法。直接好處是,雖然DOM4J付出了更復雜的API的代價,但是它提供了比JDOM大得多的靈活性。在添加靈活性、XPath集成和對大文檔處理的目標時,DOM4J的目標與JDOM是一樣的:針對Java開發者的易用性和直觀操作。它還致力於成為比JDOM更完整的解決方案,實現在本質上處理所有Java/XML問題的目標。在完成該目標時,它比JDOM更少強調防止不正確的應用程序行為。

DOM4J是一個非常非常優秀的Java XML API,具有性能優異、功能強大和極端易用使用的特點,同時它也是一個開放源代碼的軟體。如今你可以看到越來越多的Java軟體都在使用DOM4J來讀寫XML,特別值得一提的是連Sun的JAXM也在用DOM4J。

比較

1、DOM4J性能最好,連Sun的JAXM也在用DOM4J。目前許多開源項目中大量採用DOM4J,例如大名鼎鼎的Hibernate也用DOM4J來讀取XML配置文件。如果不考慮可移植性,那就採用DOM4J。

2、JDOM和DOM在性能測試時表現不佳,在測試10M文檔時內存溢出。在小文檔情況下還值得考慮使用DOM和JDOM。雖然JDOM的開發者已經說明他們期望在正式發行版前專注性能問題,但是從性能觀點來看,它確實沒有值得推薦之處。另外,DOM仍是一個非常好的選擇。DOM實現廣泛應用於多種編程語言。它還是許多其它與XML相關的標準的基礎,因為它正式獲得W3C推薦(與基於非標準的Java模型相對),所以在某些類型的項目中可能也需要它(如在JavaScript中使用DOM)。

3、SAX表現較好,這要依賴於它特定的解析方式-事件驅動。一個SAX檢測即將到來的XML流,但並沒有載入到內存(當然當XML流被讀入時,會有部分文檔暫時隱藏在內存中)

網頁鏈接

『捌』 java 關於使用SAX實現xml的解析

一,在XML文檔的DOM(文檔對象模型)
解析版本定義了一組介面。解析器讀取整個文件,然後生成一個內存中的樹結構,然後代碼就可以使用DOM介面來操作的樹形結構。
優勢:在內存中,便於操作的整個文檔樹;支持刪除,,重排等功能;
缺點:將整個文檔到內存(包括無用的節點),浪費了時間和空間;
使用:一旦解決了多次訪問這些數據所需要的文件;
足夠的硬體資源(內存,CPU)
二,SAX
DOM來解決問題,出現了SAX。
SAX,事件驅動的。當解析器發現元素的開始和結束元素,文本,等等的開始或在文檔的末尾,發送一個事件,寫程序員響應代碼對於這些事件,保存該數據。
優點:無需事先轉移,佔用資源少,整個文檔;
SAX解析器代碼比DOM解析器的代碼更小,適合小程序,下載
缺點:不是持久的;活動結束後,如果沒有保存數據,那麼數據丟失;
無狀態的;你只能從事件的文字,但我不知道該文本屬於哪個元素;
場合:小程序;
只是少量的XML文檔,幾回訪問的內容;少
機內存;
3,JDOM
減少DOM,SAX代碼量,出現了JDOM;
優點:20-80原則,極大地減少了代碼
使用量:實現一個簡單的功能,如解析度,創建等,但在底部,JDOM或使用SAX(最常見的) ,DOM,Xanan
4,JAXP
提供多個XML解析器一個統一的編程介面
更換解析器,不更改代碼
使用:如果沒有JDOM中,一般建議使用JAPX,實施與各種解析器隔離代碼的細節。

Java的XML操作應該是最常用的開源包JDOM,

『玖』 求java解析xml文檔的sax方法

ava的sax解析是基於事件的解析:當解析到xml的某個部分的時候,會觸發特定事件,可以在自定義的解析類中定義當事件觸發時要做得事情。
我們可以繼承org.xml.sax.helpers.DefaultHandler類(該類是org.xml.sax.helpers.ContentHandler的介面實現類)來覆蓋ContentHandler介面的各種方法,這些方法將定義各個事件所觸發的程序動作。
package com.thomas.xml.sax;
import org.xml.sax.Attributes;
import org.xml.sax.Locator;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class ThomasSAXHandler extends DefaultHandler {

private StringBuffer xml;//格式化後的XML文件內容
private static int step = 0;//元素層次

public ThomasSAXHandler(){
this.xml = new StringBuffer();
}

public StringBuffer getXml() {
return xml;
}
public void setXml(StringBuffer xml) {
this.xml = xml;
}
/**
* 給字元串添加TAB,使其能格式化輸出,在這里第step層元素縮進step個Tab
*/
private void appendTab(){
for(int i = 1 ; i<step; i++){
for(int j = 0 ;j<4; j++){
xml.append(' ');
}
}
}
/**
* 接收元素中字元數據的通知。
* @param ch - 字元。
* @param start - 字元數組中的開始位置。
* @param length - 從字元數組中使用的字元數。
*/
public void characters(char[] ch, int start, int length) throws SAXException {
String text = new String(ch,start,length);
text = text.trim();
if(!text.equals("")){
step++;
appendTab();
xml.append(text).append("\r\n");
step--;
}
}
/**
* 接收文檔的結尾的通知。
* @exception SAXException - 任何 SAX 異常,可能包裝另外的異常。
*/
public void endDocument() throws SAXException {
// TODO Auto-generated method stub
}
/**
* 接收元素結束的通知
* @param uri - 名稱空間 URI,如果元素沒有任何名稱空間 URI,或者沒有正在執行名稱空間處理,則為空字元串。
* @param localName - 本地名稱(不帶前綴),如果沒有正在執行名稱空間處理,則為空字元串。
* @param qName - 限定的名稱(帶有前綴),如果限定的名稱不可用,則為空字元串。
* @exception SAXException - 任何 SAX 異常,可能包裝另外的異常。
*/
public void endElement(String uri, String localName, String qName) throws SAXException {
appendTab();
xml.append("</");
if(!uri.equals("")){
xml.append(uri+":");
}
xml.append(qName).append(">\r\n");
step--;
}
/**
* 結束前綴 URI 范圍的映射。
* @param prefix - 被映射的前綴。當默認的映射范圍結束時,這是一個空字元串。
* @exception SAXException - 客戶端可能會在處理期間拋出一個異常
*/
public void endPrefixMapping(String prefix) throws SAXException {
// TODO Auto-generated method stub
}
/**
* 接收元素內容中可忽略的空白的通知。
* @param ch 來自 XML 文檔的字元
* @param start 數組中的開始位置
* @param length 從數組中讀取的字元的個數
* @exception SAXException - 任何 SAX 異常,可能包裝另外的異常
*/
public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
// TODO Auto-generated method stub
}
/**
* 接收處理指令的通知。
* @param target 處理指令目標
* @param data 處理指令數據,如果未提供,則為 null。該數據不包括將其與目標分開的任何空白
*/
public void processingInstruction(String target, String data) throws SAXException {
// TODO Auto-generated method stub
}
/**
* 接收用來查找 SAX 文檔事件起源的對象
* @param locator 可以返回任何 SAX 文檔事件位置的對象
*/
public void setDocumentLocator(Locator locator) {
// TODO Auto-generated method stub
}
/**
* 接收跳過的實體的通知。將不為標記結構(如元素開始標記或標記聲明)內的實體引用調用此方法。(XML 建議書要求報告所跳過的外部實體。SAX 還報告內部實體擴展 / 非擴展,但不包括在標記結構內部。)
* @param name - 所跳過的實體的名稱。如果它是參數實體,則名稱將以 '%' 開頭,如果它是外部 DTD 子集,則將是字元串 "[dtd]"
* @exception SAXException - 任何 SAX 異常,可能包裝另外的異常
*/
public void skippedEntity(String name) throws SAXException {
// TODO Auto-generated method stub
}
/**
* 接收文檔的開始的通知
* @exception - SAXException - 任何 SAX 異常,可能包裝另外的異常
*/
public void startDocument() throws SAXException {
// TODO Auto-generated method stub
}
/**
* 接收元素開始的通知。
* @param uri - 名稱空間 URI,如果元素沒有任何名稱空間 URI,或者沒有正在執行名稱空間處理,則為空字元串。
* @param localName - 本地名稱(不帶前綴),如果沒有正在執行名稱空間處理,則為空字元串。
* @param qName - 限定的名稱(帶有前綴),如果限定的名稱不可用,則為空字元串。
* @param attributes - 附加到元素的屬性。如果沒有屬性,則它將是空的 Attributes 對象。
* @exception SAXException - 任何 SAX 異常,可能包裝另外的異常
*/
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
step++;//元素層次加一
appendTab();
xml.append("<");
if(!uri.equals("")){
xml.append(uri+":");
}
xml.append(qName);
for(int i = 0, size = attributes.getLength(); i<size; i++){
xml.append(' ').append(attributes.getQName(i)).append("=\"").append(attributes.getValue(i)).append("\"");
}
xml.append(">\r\n");
}
/**
* 開始前綴 URI 名稱空間范圍映射。
* @param prefix - 聲明的名稱空間前綴。對於沒有前綴的默認元素名稱空間,使用空字元串。
* @param uri - 將前綴映射到的名稱空間 URI
* @exception - SAXException - 客戶端可能會在處理期間拋出一個異常
*/
public void startPrefixMapping(String prefix, String uri) throws SAXException {
// TODO Auto-generated method stub
}
}

上面是我們自定義的解析器,可以在帶有main方法的類中加以測試
package com.thomas.xml.sax;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.InputSource;

public class Test {
public static void main(String[] args){
try{
SAXParserFactory sf = SAXParserFactory.newInstance();
SAXParser sp = sf.newSAXParser();
ThomasSAXHandler handler = new ThomasSAXHandler();
sp.parse(new InputSource("film.xml"),handler);
System.out.println(handler.getXml());
}
catch(Exception e){
e.printStackTrace();
}
}
}
下面是film.xml
<?xml version="1.0" encoding="gb2312"?>
<Kungfu-vips>
<vip>
<name lang="en,ch">Bruce Li</name>
<age>32</age>
<sex>male</sex>
</vip>
<vip>
<name lang="en,ch">Jakie Chen</name>
<age>39</age>
<sex>male</sex>
</vip>
<vip>
<name lang="en,ch">Jet Li</name>
<age>39</age>
<sex>male</sex>
</vip>
</Kungfu-vips>
運行test類,可以看到輸出結果:
<Kungfu-vips>
<vip>
<name lang="en,ch">
Bruce Li
</name>
<age>
32
</age>
<sex>
male
</sex>
</vip>
<vip>
<name lang="en,ch">
Jakie Chen
</name>
<age>
39
</age>
<sex>
male
</sex>
</vip>
<vip>
<name lang="en,ch">
Jet Li
</name>
<age>
39
</age>
<sex>
male
</sex>
</vip>
</Kungfu-vips>

『拾』 用JAVA的SAX解析xml文件能解析出注釋嗎

用 dom4j / jdom 都可以

jar包 :dom4j.jar
/*
* 使用Dom4j來解析xml
*/
public static void parseXML()
{

SAXReader parser=new SAXReader();//dom4j的解析器

Reader reader;
try{
reader = new FileReader("People.xml");
Document doc=parser.read(reader); //把xml載入到document對象中

Element root=doc.getRootElement(); //按照樹的思想進行解析
List<Element> list=root.elements();//得到下一級元素集合 elementIterator()
for(Element people:list)//people
{

String eleName=people.getName();//元素名

List<Attribute> attributes=people.attributes();//屬性的集合

for(Attribute attribute:attributes)

{

String attName=attribute.getName();

String attValue=attribute.getValue();

System.out.println(attName+"---"+attValue);

}
//得到people的下一級元素

List<Element> peoplePros=people.elements();

for(Element pro:peoplePros)

{
String peopleProName=pro.getName();
String peopleProValue=pro.getTextTrim();
System.out.println(peopleProName+"----"+peopleProValue);

}
}
}catch(Exception e){
e.printStackTrace();
}
}

自己研究下

熱點內容
b樹磁碟存儲 發布:2025-01-31 19:42:53 瀏覽:837
聯想小新air15怎麼配置環境 發布:2025-01-31 19:06:57 瀏覽:968
什麼配置玩3a 發布:2025-01-31 19:05:22 瀏覽:586
phpoa系統 發布:2025-01-31 18:58:42 瀏覽:10
值e的編程 發布:2025-01-31 18:57:06 瀏覽:977
安卓手機的軟體認證在哪裡 發布:2025-01-31 18:57:01 瀏覽:535
android彈出來 發布:2025-01-31 18:56:56 瀏覽:232
辦公室白領新解壓方法 發布:2025-01-31 18:55:23 瀏覽:558
摩斯密碼短長是什麼意思 發布:2025-01-31 18:50:17 瀏覽:587
類的訪問修飾 發布:2025-01-31 18:42:46 瀏覽:933