搜尋
首頁後端開發XML/RSS教程XML解析之JAXP案例詳解

XML解析之JAXP案例詳解

Feb 16, 2017 pm 03:37 PM

根據一個CRUD的案例,對JAXP解析xml技術,進行詳細的解釋:


首先,已知一個xml檔案中的資料如下:


<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<书架>
	<书 出版社="深圳出版社1"><!-- 出版社="深圳出版社1"属性名和属性值 -->
		<书名>Java</书名>
		<作者>张泽华</作者>
		<售价>39.00元</售价>
	</书>
	<书 出版社="深圳出版社2">
		<书名>JavaScript网页开发</书名>
		<作者>李红蕾</作者>
		<售价>28.00元</售价>
	</书>
</书架>


CRUD分別寫在一個測試框架方法裡面。以方便測試程式碼正確性。



package com.itheima.dom;

import java.io.IOException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.TransformerFactoryConfigurationError;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import junit.framework.Assert;

import org.junit.Test;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

/*
 * 
 * 			使用 xml  dom 对xml 文件进行 CRUD操作 
 * 
 1.读取节点的文本内容
 2.读取属性值
 3.添加节点
 4.删除节点
 5.更新节点
 6.打印所有元素节点的名称.
 protected的方法,不让new对象

 * 
 */
public class TestDomExercises {

	// 读取节点的文本内容 : Java就业培训教程
	@Test
	public void testReadContent() throws Exception {// 测试框架异常需要抛出

		// 获得代表xml 文件的document 对象

		Document document = getDocument();

		// 根据标签名 获得 名的标签的 节点 列表
		NodeList nl= document.getElementsByTagName("书名");

		int length = nl.getLength();

		System.out.println("长度 : " + length);

		// 返回第一个 书名 节点
		Node firstBookNameNode = nl.item(0);

		String result = firstBookNameNode.getTextContent();//String getTextContent()  此属性返回此节点及其后代的文本内容。 

		Assert.assertEquals("Java", result);
	}

	// 2.读取属性值 : 出版社="深圳出版社1"
	@Test
	public void testReadAttribute() throws Exception {

		// 获得document 对象
		Document document = getDocument();

		NodeList nl = document.getElementsByTagName("书");

		// 拿到 第一本书的 节点 对象
		// Node firstBookNode = nl.item(0);

		// 注意:这里查看api 之后, 发现Node里面没有【根据 属性名获得属性值】的方法,而 元素 element 有 直接【根据 属性名获得属性值】的方法, 而这里 拿到的 实际上就是
		// 一个 元素 Node节点, 所以 这里 想到了强制类型 转换 , 转换为 元素Element , 然后 根据他的方法的属性名获得属性的值

		// 拿到 第一本书
		//nl.item(0)返回Node对象,向下转型成Element对象。因为Element里面有直接根据元素找值得方法:getAttribute("出版社");根据名称获取属性的值
		Element firstBookElement = (Element) nl.item(0);

		//String getAttribute(String name) 通过名称获得属性值。 
		String result = firstBookElement.getAttribute("出版社");//根据属性名获取属性值

		Assert.assertEquals("深圳出版社1", result);

	}

	// 3.添加节点 : <售价>79.00元</售价>
	@Test
	public void testAddPrice() throws Exception, SAXException, IOException {

		// 获得document 对象
		Document document = getDocument();

		// 获得第一本书 节点
		Node firstBookNode = document.getElementsByTagName("书").item(0);

		// 创建 售价 节点, 并且将 文本设置为 79.00元
		//Element org.w3c.dom.Document.createElement(String tagName)
		//Element createElement(String tagName) 创建指定类型的元素。 
		Element createPriceElement = document.createElement("售价");
		//
		createPriceElement.setTextContent("79.00元");//<售价>79.00元</售价>

		//Node org.w3c.dom.Node.appendChild(Node newChild) 
		firstBookNode.appendChild(createPriceElement);//将节点 newChild 添加到此节点的子节点列表的末尾。如果 newChild 已经存在于树中,则首先移除它。

		writeBack2Xml(document);

	}

	/*
	 * 回去写代码时, 如果碰到这个 异常 :
	 * 
	 * initializationError(org.junit.runner.manipulation.Filter)
	 * 
	 * 就是 你 没有 加 @Test 注解
	 */

	// 4.删除节点: <售价>39.00元</售价>
	@Test
	public void testDelete() throws Exception, SAXException, IOException {

		// 获得 document 对象
		Document document = getDocument();

		// 获得 售价 39.00元的 节点
		NodeList priceNodeList = document.getElementsByTagName("售价");

		for (int i = 0; i < priceNodeList.getLength(); i++) {

			// 拿到 每个售价节点
			Node node = priceNodeList.item(i);

			if ("39.00元".equals(node.getTextContent())) {

				// 如果进来, 则说明找到 39.00元的售价节点
				// 拿到当前节点的父节点, 然后 删除 这个 节点
				node.getParentNode().removeChild(node);

			}
		}

		// 更新 到 xml 文件
		writeBack2Xml(document);

	}

	// 5.更新节点 : <售价>79.00元</售价> ---------->> <售价>9.9元</售价>
	public void testUpdatePrice() {

	}

	// 6.打印所有元素节点的名称.

	@Test
	public void testPrintAllElementsName() throws Exception, SAXException,
			IOException {

		// 获得document 对象
		Document document = getDocument();

		printAllElementsName(document);
	}

	public void printAllElementsName(Node node) {

		if (Node.ELEMENT_NODE == node.getNodeType()) {

			// 说明 就是 元素 节点
			System.out.println(node.getNodeName());
		}

		NodeList childNodes = node.getChildNodes();

		for (int i = 0; i < childNodes.getLength(); i++) {

			// 拿到 遍历过程中的 每一个 node
			Node item = childNodes.item(i);

			printAllElementsName(item);
		}
	}

	// 需要将内存中的document 对象 重新写回到 xml 文件中去
	private void writeBack2Xml(Document document)
			throws TransformerFactoryConfigurationError,
			TransformerConfigurationException, TransformerException {

		// 如何弄?
		// 查看 文档, transformerFacotry --->> Transformer实例

		TransformerFactory factory = TransformerFactory.newInstance();

		// 获得转换器的 实例对象
		Transformer transformer = factory.newTransformer();

		// 调用 转换方法 将 内存中document 对象 写到 xml 文件中 去
		//abstract  void transform(Source xmlSource, Result outputTarget) 将 XML Source 转换为 Result。 
		//DOMSource正好是Source实现类。而且它有构造方法DOMSource(Node n) 正好接收一个Node
		//Result实现类有一个StreamResult他的构造方法StreamResult.StreamResult(String systemId)
// systemId:Must be a String that conforms to the URI syntax
		//因此源Source,和结果Result都解决了
		transformer.transform(new DOMSource(document), new StreamResult(
				"src/book.xml"));
	}

	// 抽取 方法 (右键——>>refactor--->>rctract method)--->> 重构 -- 抽取 方法
	private Document getDocument() throws ParserConfigurationException,
			SAXException, IOException {
		// 1. 获得工厂
		DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

		// 2. 获得 builder 对象
		DocumentBuilder builder = factory.newDocumentBuilder();

		// 3. 拿到 代表xml 文件的document 对象
		Document document = builder.parse("src/book.xml");
		return document;
	}

}

 以上是XML解析之JAXP案例詳解的內容,更多相關內容請關注PHP中文網(www.php.cn)!


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
理解RSS:XML觀點理解RSS:XML觀點Apr 25, 2025 am 12:14 AM

RSS是一種基於XML的格式,用於發布經常更新的內容。 1.RSSfeed通過XML結構化組織信息,包括標題、鏈接、描述等。 2.創建RSSfeed需按照XML結構編寫,添加元數據如語言和發布日期。 3.高級用法可包含多媒體文件和分類信息。 4.調試時使用XML驗證工具,確保必需元素存在且編碼正確。 5.優化RSSfeed可通過分頁、緩存和保持結構簡潔來實現。通過理解和應用這些知識,可以有效管理和分發內容。

XML中的RSS:解碼標籤,屬性和結構XML中的RSS:解碼標籤,屬性和結構Apr 24, 2025 am 12:09 AM

RSS是一種基於XML的格式,用於發布和訂閱內容。 RSS文件的XML結構包括根元素、元素和多個元素,每個代表一個內容條目。通過XML解析器讀取和解析RSS文件,用戶可以訂閱並獲取最新內容。

XML在RSS中的優勢:技術深度潛水XML在RSS中的優勢:技術深度潛水Apr 23, 2025 am 12:02 AM

XML在RSS中具有結構化數據、可擴展性、跨平台兼容性和解析驗證的優勢。 1)結構化數據確保內容的一致性和可靠性;2)可擴展性允許添加自定義標籤以適應內容需求;3)跨平台兼容性使其在不同設備上無縫工作;4)解析和驗證工具確保Feed的質量和完整性。

XML中的RSS:揭示內容聯合的核心XML中的RSS:揭示內容聯合的核心Apr 22, 2025 am 12:08 AM

RSS在XML中的實現方式是通過結構化的XML格式來組織內容。 1)RSS使用XML作為數據交換格式,包含頻道信息和項目列表等元素。 2)生成RSS文件需按規範組織內容,發佈到服務器供訂閱。 3)RSS文件可通過閱讀器或插件訂閱,實現內容自動更新。

超越基礎:高級RSS文檔功能超越基礎:高級RSS文檔功能Apr 21, 2025 am 12:03 AM

RSS的高級功能包括內容命名空間、擴展模塊和條件訂閱。 1)內容命名空間擴展RSS功能,2)擴展模塊如DublinCore或iTunes添加元數據,3)條件訂閱根據特定條件篩選條目。這些功能通過添加XML元素和屬性實現,提升信息獲取效率。

XML主鏈:RSS提要如何結構XML主鏈:RSS提要如何結構Apr 20, 2025 am 12:02 AM

RSSFEEDSUSEXMLTOSSTRUCTURECONTUPDATE.1)XMLPROVIDEDIDESAHIERARCHICALSTRUCTUREFFORDATA.2)THEELEMENTDEFINESTHEEFEED'SIDENTITYANDCONTAINS ELEMENT.3)ELEMENTEMERPREPRESERPRESENTERPRESENTIVIDIVIVELPIECTUALPIECES.4)RSSSSSSSSSSSISEXTEXTENSIBLERECTICERSINCREECTINCERINCTICENT.5)

RSS和XML:了解Web內容的動態二重奏RSS和XML:了解Web內容的動態二重奏Apr 19, 2025 am 12:03 AM

RSS和XML是用於網絡內容管理的工具。 RSS用於發布和訂閱內容,XML用於存儲和傳輸數據。它們的工作原理包括內容髮布、訂閱和更新推送。使用示例包括RSS發布博客文章和XML存儲書籍信息。

RSS文檔:Web聯合組織的基礎RSS文檔:Web聯合組織的基礎Apr 18, 2025 am 12:04 AM

RSS文檔是基於XML的結構化文件,用於發布和訂閱頻繁更新的內容。它的主要作用包括:1)自動化內容更新,2)內容聚合,3)提高瀏覽效率。通過RSSfeed,用戶可以訂閱並及時獲取來自不同來源的最新信息。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。