Heim Backend-Entwicklung XML/RSS-Tutorial Detaillierte Erläuterung des JAXP-Falls der XML-Analyse

Detaillierte Erläuterung des JAXP-Falls der XML-Analyse

Feb 16, 2017 pm 03:37 PM

Anhand eines CRUD-Falls eine detaillierte Erklärung der JAXP-XML-Parsing-Technologie:


Zunächst ist bekannt, dass die Daten in einer XML-Datei wie folgt lauten :


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


Dann wird CRUD gemäß der Unit-Test-Form in einer Test-Framework-Methode geschrieben. Um das Testen der Richtigkeit des Codes zu erleichtern.



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;
	}

}
Nach dem Login kopieren

Das Obige ist die detaillierte Erklärung des JAXP-Falls der XML-Analyse. Weitere verwandte Inhalte finden Sie hier Achten Sie auf die chinesische PHP-Website (www.php.cn)!


Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Verwenden Sie das Gin-Framework, um XML- und JSON-Datenanalysefunktionen zu implementieren Verwenden Sie das Gin-Framework, um XML- und JSON-Datenanalysefunktionen zu implementieren Jun 22, 2023 pm 03:14 PM

Im Bereich der Webentwicklung sind XML und JSON, eines der Datenformate, weit verbreitet. Das Gin-Framework ist ein leichtes Web-Framework in der Go-Sprache, das einfach, benutzerfreundlich und effizient ist. In diesem Artikel wird erläutert, wie Sie mit dem Gin-Framework XML- und JSON-Datenanalysefunktionen implementieren. Übersicht über das Gin-Framework Das Gin-Framework ist ein auf der Go-Sprache basierendes Web-Framework, mit dem effiziente und skalierbare Webanwendungen erstellt werden können. Das Gin-Framework ist so konzipiert, dass es einfach und benutzerfreundlich ist. Es bietet eine Vielzahl von Middleware und Plug-Ins für die Entwicklung

Java-Fehler: XML-Parsing-Fehler, wie man ihn behebt und vermeidet Java-Fehler: XML-Parsing-Fehler, wie man ihn behebt und vermeidet Jun 24, 2023 pm 05:46 PM

Da Java im Internetbereich immer häufiger eingesetzt wird, stoßen viele Entwickler möglicherweise auf das Problem eines „XML-Parsing-Fehlers“, wenn sie XML zum Parsen von Daten verwenden. Ein XML-Analysefehler bedeutet, dass das Programm bei Verwendung von Java zum Parsen von XML-Daten die Daten aufgrund eines falschen Datenformats, nicht geschlossener Tags oder aus anderen Gründen nicht normal analysieren kann, was zu Fehlern und Ausnahmen führt. Wie können wir also Fehler beim XML-Parsing lösen und vermeiden? In diesem Artikel wird dieses Problem ausführlich erläutert. 1. XML-Analyse

So lösen Sie das Problem der hohen Speichernutzung beim XML-Parsing in der Java-Entwicklung So lösen Sie das Problem der hohen Speichernutzung beim XML-Parsing in der Java-Entwicklung Jun 29, 2023 am 09:37 AM

XML ist ein häufig verwendetes Datenaustauschformat. In der Java-Entwicklung müssen häufig große XML-Dateien analysiert werden. Da XML-Dateien jedoch oft eine große Anzahl an Knoten und Elementen enthalten, können herkömmliche XML-Parsing-Methoden leicht zu einer hohen Speichernutzung führen. In diesem Artikel werden einige Methoden vorgestellt, um das Problem der hohen Speichernutzung beim XML-Parsen zu lösen. Verwendung des SAX-Parsers SAX (SimpleAPI for XML) ist eine ereignisgesteuerte XML-Parsing-Methode. Im Vergleich zu DOM (DokumentO

So verwenden Sie PHP zum Parsen von XML und zum Abrufen von Knoteninhalten So verwenden Sie PHP zum Parsen von XML und zum Abrufen von Knoteninhalten Jun 13, 2023 pm 04:31 PM

Bei der Entwicklung von Webanwendungen ist XML ein sehr wichtiges Datenformat, das in Szenarien wie dem Datenaustausch und der Informationsfreigabe verwendet werden kann. In PHP können wir integrierte Funktionen und Bibliotheken von Drittanbietern verwenden, um XML zu analysieren und zu bearbeiten. Im Folgenden besprechen wir, wie Sie PHP verwenden, um XML zu analysieren und den Inhalt der darin enthaltenen Knoten abzurufen. XML-Dateien analysieren Zuerst müssen wir XML-Dateien analysieren. PHP bietet zwei Hauptmethoden zum Parsen von XML: 1.1 Verwendung von SimpleXML SimpleXML ist in PHP enthalten

PHP8.1-Update: erweiterte XML-Parsing-Funktionen PHP8.1-Update: erweiterte XML-Parsing-Funktionen Jul 07, 2023 am 09:22 AM

PHP8.1-Update: Erweiterte XML-Parsing-Funktion Mit der rasanten Entwicklung des Internets spielt XML (Extensible Markup Language) eine wichtige Rolle beim Datenaustausch und der Informationsübertragung. Als universelles Datenformat wird XML häufig zur Übertragung und Speicherung von Daten zwischen verschiedenen Anwendungen verwendet. Um bessere XML-Parsing-Funktionen bereitzustellen, hat PHP8.1 die XML-Parsing-Funktion erweitert, um Entwicklern mehr Komfort zu bieten. Eine wichtige Verbesserung in PHP8.1 ist die Einführung von libxml_disabl

Lösung zur Lösung der Java XML-Parsing-Ausnahme (XMLParsingException) Lösung zur Lösung der Java XML-Parsing-Ausnahme (XMLParsingException) Aug 19, 2023 pm 01:43 PM

Lösungseinführung zum Lösen von JavaXML-Parsing-Ausnahmen (XMLParsingException): Bei der Verarbeitung von XML-Dateien treten häufig XML-Parsing-Ausnahmen (XMLParsingException) auf. Diese werden durch XML-Dateiformatfehler oder eine falsche XML-Parser-Konfiguration verursacht. In diesem Artikel werden einige häufige XML-Parsing-Ausnahmen und Lösungen vorgestellt, um Entwicklern dabei zu helfen, diese Probleme besser zu bewältigen. 1. Die Ursache der XML-Parsing-Ausnahme ist das Parsen eines XML-Dokuments.

Wie gehe ich mit XML-Parsing-Fehlern in PHP um? Wie gehe ich mit XML-Parsing-Fehlern in PHP um? Dec 02, 2023 pm 02:58 PM

PHP ist eine weit verbreitete Programmiersprache, die viele verschiedene Dateiformate unterstützt, einschließlich XML. Bei der Verarbeitung von XML-Dateien können Parsing-Fehler auftreten. In diesem Artikel wird erläutert, wie mit XML-Parsing-Fehlern in PHP umgegangen wird, und einige konkrete Codebeispiele bereitgestellt. Überprüfen des XML-Dateiformats Bevor Sie eine XML-Datei verarbeiten, müssen Sie sicherstellen, dass die XML-Datei das richtige Format hat. Die XML-Datei muss in einem strikten Format vorliegen, andernfalls kann der Parser die Datei nicht verarbeiten. Beispielsweise muss die XML-Datei das Stammelement enthalten und den richtigen Namespace verwenden.

So reduzieren Sie die Speichernutzung beim XML-Parsing in der Java-Entwicklung So reduzieren Sie die Speichernutzung beim XML-Parsing in der Java-Entwicklung Jun 30, 2023 pm 09:19 PM

So lösen Sie das Problem, dass XML-Parsing zu viel Heap-Speicher in der Java-Entwicklung belegt. Einführung: Mit dem explosionsartigen Wachstum von Informationen und Daten nimmt die Bedeutung von XML (Extensible Markup Language) in der Entwicklung von Unternehmensanwendungen weiter zu. Allerdings kann es beim XML-Parsing zu Problemen mit übermäßiger Heap-Speichernutzung kommen, insbesondere beim Umgang mit großen XML-Dateien. In diesem Artikel werden einige Methoden und Techniken zur Lösung dieses Problems vorgestellt. 1. Verstehen Sie den XML-Parsing-Prozess. Bevor wir das Problem, dass das XML-Parsing zu viel Heap-Speicher belegt, gründlich lösen, verstehen wir zunächst die Grundlagen des XML-Parsings.

See all articles