使用java解析名稱空間的方法,Java 命名空間

本文目錄一覽:

在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里的命名空間是用什麼方式實現的???

入struts2中的配置文件裡面寫入namespace=”user”

那麼在地址欄中跳轉jsp時候在地址會顯示為 : /應用名/user/相關jsp

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解析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 ; istep; i++){

for(int j = 0 ;j4; 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(); isize; 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

age32/age

sexmale/sex

/vip

vip

name lang=”en,ch”Jakie Chen/name

age39/age

sexmale/sex

/vip

vip

name lang=”en,ch”Jet Li/name

age39/age

sexmale/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

原創文章,作者:MDBB,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/144956.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
MDBB的頭像MDBB
上一篇 2024-10-26 11:54
下一篇 2024-10-26 11:54

相關推薦

  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • ArcGIS更改標註位置為中心的方法

    本篇文章將從多個方面詳細闡述如何在ArcGIS中更改標註位置為中心。讓我們一步步來看。 一、禁止標註智能調整 在ArcMap中設置標註智能調整可以自動將標註位置調整到最佳顯示位置。…

    編程 2025-04-29
  • 解決.net 6.0運行閃退的方法

    如果你正在使用.net 6.0開發應用程序,可能會遇到程序閃退的情況。這篇文章將從多個方面為你解決這個問題。 一、代碼問題 代碼問題是導致.net 6.0程序閃退的主要原因之一。首…

    編程 2025-04-29
  • Python創建分配內存的方法

    在python中,我們常常需要創建並分配內存來存儲數據。不同的類型和數據結構可能需要不同的方法來分配內存。本文將從多個方面介紹Python創建分配內存的方法,包括列表、元組、字典、…

    編程 2025-04-29
  • Python中init方法的作用及使用方法

    Python中的init方法是一個類的構造函數,在創建對象時被調用。在本篇文章中,我們將從多個方面詳細討論init方法的作用,使用方法以及注意點。 一、定義init方法 在Pyth…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29

發表回復

登錄後才能評論