日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

详解Java解析XML的四种方法(转载)

發(fā)布時間:2025/4/5 asp.net 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 详解Java解析XML的四种方法(转载) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

原文地址:http://developer.51cto.com/art/200903/117512.htm

XML現(xiàn)在已經(jīng)成為一種通用的數(shù)據(jù)交換格式,它的平臺無關(guān)性,語言無關(guān)性,系統(tǒng)無關(guān)性,給數(shù)據(jù)集成與交互帶來了極大的方便。對于XML本身的語法知 識與技術(shù)細(xì)節(jié),需要閱讀相關(guān)的技術(shù)文獻(xiàn),這里面包括的內(nèi)容有DOM(Document Object Model),DTD(Document Type Definition),SAX(Simple API for XML),XSD(Xml Schema Definition),XSLT(Extensible Stylesheet Language Transformations),具體可參閱w3c官方網(wǎng)站文檔http://www.w3.org獲取更多信息。

XML在不同的語言里解析方式都是一樣的,只不過實(shí)現(xiàn)的語法不同而已。基本的解析方式有兩種,一種叫SAX,另一種叫DOM。SAX是基于事件流的解析,DOM是基于XML文檔樹結(jié)構(gòu)的解析。假設(shè)我們XML的內(nèi)容和結(jié)構(gòu)如下:

<?xml version="1.0" encoding="UTF-8"?> <employees> <employee> <name>ddviplinux</name> <sex>m</sex> <age>30</age> </employee> </employees>

?本文使用JAVA語言來實(shí)現(xiàn)DOM與SAX的XML文檔生成與解析。
首先定義一個操作XML文檔的接口XmlDocument 它定義了XML文檔的建立與解析的接口。

package com.alisoft.facepay.framework.bean; /** * * @author hongliang.dinghl * 定義XML文檔建立與解析的接口 */ public interface XmlDocument { /** * 建立XML文檔 * @param fileName 文件全路徑名稱 */ public void createXml(String fileName); /** * 解析XML文檔 * @param fileName 文件全路徑名稱 */ public void parserXml(String fileName); }

1.DOM生成和解析XML文檔

為 XML 文檔的已解析版本定義了一組接口。解析器讀入整個文檔,然后構(gòu)建一個駐留內(nèi)存的樹結(jié)構(gòu),然后代碼就可以使用 DOM 接口來操作這個樹結(jié)構(gòu)。優(yōu)點(diǎn):整個文檔樹在內(nèi)存中,便于操作;支持刪除、修改、重新排列等多種功能;缺點(diǎn):將整個文檔調(diào)入內(nèi)存(包括無用的節(jié)點(diǎn)),浪費(fèi)時 間和空間;使用場合:一旦解析了文檔還需多次訪問這些數(shù)據(jù);硬件資源充足(內(nèi)存、CPU)。

1 package com.alisoft.facepay.framework.bean; 2 import java.io.FileInputStream; 3 import java.io.FileNotFoundException; 4 import java.io.FileOutputStream; 5 import java.io.IOException; 6 import java.io.InputStream; 7 import java.io.PrintWriter; 8 import javax.xml.parsers.DocumentBuilder; 9 import javax.xml.parsers.DocumentBuilderFactory; 10 import javax.xml.parsers.ParserConfigurationException; 11 import javax.xml.transform.OutputKeys; 12 import javax.xml.transform.Transformer; 13 import javax.xml.transform.TransformerConfigurationException; 14 import javax.xml.transform.TransformerException; 15 import javax.xml.transform.TransformerFactory; 16 import javax.xml.transform.dom.DOMSource; 17 import javax.xml.transform.stream.StreamResult; 18 import org.w3c.dom.Document; 19 import org.w3c.dom.Element; 20 import org.w3c.dom.Node; 21 import org.w3c.dom.NodeList; 22 import org.xml.sax.SAXException; 23 /** 24 * 25 * @author hongliang.dinghl 26 * DOM生成與解析XML文檔 27 */ 28 public class DomDemo implements XmlDocument { 29 private Document document; 30 private String fileName; 31 public void init() { 32 try { 33 DocumentBuilderFactory factory = DocumentBuilderFactory 34 .newInstance(); 35 DocumentBuilder builder = factory.newDocumentBuilder(); 36 this.document = builder.newDocument(); 37 } catch (ParserConfigurationException e) { 38 System.out.println(e.getMessage()); 39 } 40 } 41 public void createXml(String fileName) { 42 Element root = this.document.createElement("employees"); 43 this.document.appendChild(root); 44 Element employee = this.document.createElement("employee"); 45 Element name = this.document.createElement("name"); 46 name.appendChild(this.document.createTextNode("丁宏亮")); 47 employee.appendChild(name); 48 Element sex = this.document.createElement("sex"); 49 sex.appendChild(this.document.createTextNode("m")); 50 employee.appendChild(sex); 51 Element age = this.document.createElement("age"); 52 age.appendChild(this.document.createTextNode("30")); 53 employee.appendChild(age); 54 root.appendChild(employee); 55 TransformerFactory tf = TransformerFactory.newInstance(); 56 try { 57 Transformer transformer = tf.newTransformer(); 58 DOMSource source = new DOMSource(document); 59 transformer.setOutputProperty(OutputKeys.ENCODING, "gb2312"); 60 transformer.setOutputProperty(OutputKeys.INDENT, "yes"); 61 PrintWriter pw = new PrintWriter(new FileOutputStream(fileName)); 62 StreamResult result = new StreamResult(pw); 63 transformer.transform(source, result); 64 System.out.println("生成XML文件成功!"); 65 } catch (TransformerConfigurationException e) { 66 System.out.println(e.getMessage()); 67 } catch (IllegalArgumentException e) { 68 System.out.println(e.getMessage()); 69 } catch (FileNotFoundException e) { 70 System.out.println(e.getMessage()); 71 } catch (TransformerException e) { 72 System.out.println(e.getMessage()); 73 } 74 } 75 public void parserXml(String fileName) { 76 try { 77 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); 78 DocumentBuilder db = dbf.newDocumentBuilder(); 79 Document document = db.parse(fileName); 80 NodeList employees = document.getChildNodes(); 81 for (int i = 0; i < employees.getLength(); i++) { 82 Node employee = employees.item(i); 83 NodeList employeeInfo = employee.getChildNodes(); 84 for (int j = 0; j < employeeInfo.getLength(); j++) { 85 Node node = employeeInfo.item(j); 86 NodeList employeeMeta = node.getChildNodes(); 87 for (int k = 0; k < employeeMeta.getLength(); k++) { 88 System.out.println(employeeMeta.item(k).getNodeName() 89 + ":" + employeeMeta.item(k).getTextContent()); 90 } 91 } 92 } 93 System.out.println("解析完畢"); 94 } catch (FileNotFoundException e) { 95 System.out.println(e.getMessage()); 96 } catch (ParserConfigurationException e) { 97 System.out.println(e.getMessage()); 98 } catch (SAXException e) { 99 System.out.println(e.getMessage()); 100 } catch (IOException e) { 101 System.out.println(e.getMessage()); 102 } 103 }
}

2.SAX生成和解析XML文檔

為解決DOM的問題,出現(xiàn)了SAX。SAX ,事件驅(qū)動。當(dāng)解析器發(fā)現(xiàn)元素開始、元素結(jié)束、文本、文檔的開始或結(jié)束等時,發(fā)送事件,程序員編寫響應(yīng)這些事件的代碼,保存數(shù)據(jù)。優(yōu)點(diǎn):不用事先調(diào)入整個 文檔,占用資源少;SAX解析器代碼比DOM解析器代碼小,適于Applet,下載。缺點(diǎn):不是持久的;事件過后,若沒保存數(shù)據(jù),那么數(shù)據(jù)就丟了;無狀態(tài) 性;從事件中只能得到文本,但不知該文本屬于哪個元素;使用場合:Applet;只需XML文檔的少量內(nèi)容,很少回頭訪問;機(jī)器內(nèi)存少;

3.DOM4J生成和解析XML文檔

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

4.JDOM生成和解析XML??

為減少DOM、SAX的編碼量,出現(xiàn)了JDOM;優(yōu)點(diǎn):20-80原則,極大減少了代碼量。使用場合:要實(shí)現(xiàn)的功能簡單,如解析、創(chuàng)建等,但在底層,JDOM還是使用SAX(最常用)、DOM、Xanan文檔。

?

轉(zhuǎn)載于:https://www.cnblogs.com/davidwang456/archive/2013/04/02/2995638.html

總結(jié)

以上是生活随笔為你收集整理的详解Java解析XML的四种方法(转载)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。