백엔드 개발 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으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Gin 프레임워크를 사용하여 XML 및 JSON 데이터 구문 분석 기능 구현 Gin 프레임워크를 사용하여 XML 및 JSON 데이터 구문 분석 기능 구현 Jun 22, 2023 pm 03:14 PM

웹 개발 분야에서는 데이터 형식 중 하나인 XML과 JSON이 널리 사용되고 있으며, Gin 프레임워크는 간단하고 사용하기 쉬우며 효율적인 성능을 갖춘 경량의 Go 언어 웹 프레임워크입니다. 이 기사에서는 Gin 프레임워크를 사용하여 XML 및 JSON 데이터 구문 분석 기능을 구현하는 방법을 소개합니다. Gin 프레임워크 개요 Gin 프레임워크는 효율적이고 확장 가능한 웹 애플리케이션을 구축하는 데 사용할 수 있는 Go 언어 기반의 웹 프레임워크입니다. Gin 프레임워크는 간단하고 사용하기 쉽도록 설계되었으며 개발을 위한 다양한 미들웨어와 플러그인을 제공합니다.

Java 오류: XML 구문 분석 오류, 수정 및 방지 방법 Java 오류: XML 구문 분석 오류, 수정 및 방지 방법 Jun 24, 2023 pm 05:46 PM

Java가 인터넷 분야에서 점점 더 널리 사용됨에 따라 많은 개발자가 데이터 구문 분석을 위해 XML을 사용할 때 "XML 구문 분석 오류" 문제에 직면할 수 있습니다. XML 구문 분석 오류는 Java를 사용하여 XML 데이터를 구문 분석할 때 잘못된 데이터 형식, 닫히지 않은 태그 또는 기타 이유로 인해 프로그램이 데이터를 정상적으로 구문 분석할 수 없어 오류 및 예외가 발생함을 의미합니다. 그렇다면 XML 구문 분석 오류가 발생할 때 어떻게 해결하고 방지해야 할까요? 이 기사에서는 이 문제에 대해 자세히 설명합니다. 1. XML 파싱

Java 개발에서 XML 구문 분석의 높은 메모리 사용량 문제를 해결하는 방법 Java 개발에서 XML 구문 분석의 높은 메모리 사용량 문제를 해결하는 방법 Jun 29, 2023 am 09:37 AM

XML은 일반적으로 사용되는 데이터 교환 형식입니다. Java 개발에서는 대규모 XML 파일을 구문 분석해야 하는 경우가 많습니다. 그러나 XML 파일에는 많은 수의 노드와 요소가 포함되는 경우가 많기 때문에 기존 XML 구문 분석 방법을 사용하면 쉽게 메모리 사용량이 높아질 수 있습니다. 이 기사에서는 XML 구문 분석의 높은 메모리 사용량 문제를 해결하는 몇 가지 방법을 소개합니다. SAX 구문 분석기 사용 SAX(XML용 SimpleAPI)는 이벤트 기반 XML 구문 분석 방법입니다. DOM과 비교(DocumentO

PHP를 사용하여 XML을 구문 분석하고 노드 콘텐츠를 얻는 방법 PHP를 사용하여 XML을 구문 분석하고 노드 콘텐츠를 얻는 방법 Jun 13, 2023 pm 04:31 PM

웹 애플리케이션을 개발할 때 XML은 데이터 교환, 정보 공유 등의 시나리오에서 사용할 수 있는 매우 중요한 데이터 형식입니다. PHP에서는 내장 함수와 타사 라이브러리를 사용하여 XML을 구문 분석하고 조작할 수 있습니다. 아래에서는 PHP를 사용하여 XML을 구문 분석하고 그 안에 있는 노드의 내용을 얻는 방법에 대해 설명합니다. XML 파일 구문 분석 먼저 XML 파일을 구문 분석해야 합니다. PHP는 XML을 구문 분석하는 두 가지 주요 방법을 제공합니다. 1.1 SimpleXML 사용 SimpleXML은 PHP 내에 있습니다.

PHP8.1 업데이트: 향상된 XML 구문 분석 기능 PHP8.1 업데이트: 향상된 XML 구문 분석 기능 Jul 07, 2023 am 09:22 AM

PHP8.1 업데이트: 향상된 XML 구문 분석 기능 인터넷의 급속한 발전과 함께 XML(Extensible Markup Language)은 데이터 교환 및 정보 전송에서 중요한 역할을 합니다. 범용 데이터 형식인 XML은 종종 서로 다른 응용 프로그램 간에 데이터를 전송하고 저장하는 데 사용됩니다. 더 나은 XML 구문 분석 기능을 제공하기 위해 PHP8.1은 개발자에게 더 많은 편의를 제공하기 위해 XML 구문 분석 기능을 향상시켰습니다. PHP8.1에서는 libxml_disabl이 도입되어 중요한 개선이 이루어졌습니다.

Java XML 구문 분석 예외(XMLParsingException)를 해결하는 솔루션 Java XML 구문 분석 예외(XMLParsingException)를 해결하는 솔루션 Aug 19, 2023 pm 01:43 PM

Java XML 구문 분석 예외(XMLParsingException) 해결을 위한 솔루션 소개: XML 파일을 처리할 때 XML 구문 분석 예외(XMLParsingException)가 자주 발생합니다. 이는 XML 파일 형식 오류 또는 잘못된 XML 구문 분석기 구성으로 인해 발생합니다. 이 기사에서는 개발자가 이러한 문제를 더 잘 처리하는 데 도움이 되는 몇 가지 일반적인 XML 구문 분석 예외와 솔루션을 소개합니다. 1. XML 파싱 예외의 원인은 XML 문서 파싱입니다.

PHP에서 XML 구문 분석 오류를 처리하는 방법은 무엇입니까? PHP에서 XML 구문 분석 오류를 처리하는 방법은 무엇입니까? Dec 02, 2023 pm 02:58 PM

PHP는 XML을 포함하여 다양한 파일 형식을 지원하는 널리 사용되는 프로그래밍 언어입니다. XML 파일을 처리할 때 구문 분석 오류가 발생할 수 있습니다. 이 기사에서는 PHP에서 XML 구문 분석 오류를 처리하는 방법을 설명하고 몇 가지 구체적인 코드 예제를 제공합니다. XML 파일 형식 확인 XML 파일을 처리하기 전에 XML 파일이 올바른 형식인지 확인해야 합니다. XML 파일은 엄격한 형식이어야 합니다. 그렇지 않으면 파서가 파일을 처리할 수 없습니다. 예를 들어 XML 파일은 루트 요소를 포함하고 올바른 네임스페이스를 사용해야 합니다.

Java 개발에서 XML 구문 분석 메모리 사용량을 줄이는 방법 Java 개발에서 XML 구문 분석 메모리 사용량을 줄이는 방법 Jun 30, 2023 pm 09:19 PM

Java 개발에서 너무 많은 힙 메모리를 차지하는 XML 구문 분석 문제를 해결하는 방법 소개: 정보와 데이터가 폭발적으로 증가함에 따라 엔터프라이즈 애플리케이션 개발에서 XML(Extensible Markup Language)의 중요성이 계속해서 높아지고 있습니다. 그러나 특히 대용량 XML 파일을 처리할 때 XML 구문 분석 중에 과도한 힙 메모리 사용으로 인해 문제가 발생할 수 있습니다. 이 기사에서는 이 문제를 해결하기 위한 몇 가지 방법과 기술을 소개합니다. 1. XML 구문 분석 프로세스를 이해합니다. XML 구문 분석이 너무 많은 힙 메모리를 차지하는 문제를 심층적으로 해결하기 전에 먼저 XML 구문 분석의 기본 사항을 이해합니다.

See all articles