Apache Xerces-빠른 가이드
XML이란 무엇입니까?
XML은 일반 텍스트 형식으로 데이터를 저장하고 전송하도록 설계된 간단한 텍스트 기반 언어입니다. Extensible Markup Language의 약자입니다. 다음은 XML의 몇 가지 두드러진 기능입니다.
XML은 마크 업 언어입니다.
XML은 HTML과 같은 태그 기반 언어입니다.
XML 태그는 HTML처럼 미리 정의되어 있지 않습니다.
확장 가능한 언어라고하는 고유 한 태그를 정의 할 수 있습니다.
XML 태그는 자체 설명이 가능하도록 설계되었습니다.
XML은 데이터 저장 및 전송을위한 W3C 권장 사항입니다.
예
<?xml version = "1.0"?>
<Class>
<Name>First</Name>
<Sections>
<Section>
<Name>A</Name>
<Students>
<Student>Rohan</Student>
<Student>Mohan</Student>
<Student>Sohan</Student>
<Student>Lalit</Student>
<Student>Vinay</Student>
</Students>
</Section>
<Section>
<Name>B</Name>
<Students>
<Student>Robert</Student>
<Student>Julie</Student>
<Student>Kalie</Student>
<Student>Michael</Student>
</Students>
</Section>
</Sections>
</Class>
장점
다음은 XML이 제공하는 장점입니다-
Technology agnostic− 일반 텍스트이기 때문에 XML은 기술에 독립적입니다. 데이터 저장 및 전송 목적으로 모든 기술에서 사용할 수 있습니다.
Human readable− XML은 간단한 텍스트 형식을 사용합니다. 사람이 읽을 수 있고 이해할 수 있습니다.
Extensible − XML에서 사용자 정의 태그를 매우 쉽게 생성하고 사용할 수 있습니다.
Allow Validation − XSD를 사용하여 DTD 및 XML 구조를 쉽게 검증 할 수 있습니다.
단점
다음은 XML 사용의 단점입니다-
Redundant Syntax − 일반적으로 XML 파일에는 반복적 인 용어가 많이 포함되어 있습니다.
Verbose − 장황한 언어이기 때문에 XML 파일 크기는 전송 및 저장 비용을 증가시킵니다.
이 장에서는 Windows 및 Linux 기반 시스템에서 Apache Xerces를 설정하는 프로세스를 안내합니다. Apache Xerces는 복잡한 설정 절차없이 몇 가지 간단한 단계에 따라 현재 Java 환경에 쉽게 설치하고 통합 할 수 있습니다. 설치하는 동안 사용자 관리가 필요합니다.
시스템 요구 사항
JDK | Java SE 2 JDK 1.5 이상 |
기억 | 1GB RAM (권장) |
디스크 공간 | 최소 요구 사항 없음 |
운영 체제 버전 | Windows XP 이상, Linux |
이제 Apache Xerces를 설치하는 단계를 진행하겠습니다.
1 단계 : Java 설치 확인
먼저 시스템에 Java SDK (Software Development Kit)가 설치되어 있어야합니다. 이를 확인하려면 작업중인 플랫폼에 따라 두 명령 중 하나를 실행하십시오.
Java 설치에 성공하면 Java 설치의 현재 버전과 사양이 표시됩니다. 다음 표에는 샘플 출력이 나와 있습니다.
플랫폼 | 명령 | 샘플 출력 |
---|---|---|
윈도우 | 명령 콘솔을 열고 다음을 입력합니다. java -version | Java 버전 "1.7.0_60"Java (TM) SE 런타임 환경 (빌드 1.7.0_60-b19) Java Hotspot (TM) 64 비트 서버 VM (빌드 24.60b09, 혼합 모드) |
리눅스 | 명령 터미널을 열고 다음을 입력합니다. $ java -version | Java 버전 "1.7.0_25"개방형 JDK 런타임 환경 (rhel-2.3.10.4.el6_4-x86_64) 개방형 JDK 64 비트 서버 VM (빌드 23.7-b01, 혼합 모드) |
이 자습서의 독자는 시스템에 Java SDK 버전 1.7.0_60이 설치되어 있다고 가정합니다.
Java SDK가없는 경우 현재 버전을 https://www.oracle.com/technetwork/java/javase/downloads/index.html 그리고 그것을 설치하십시오.
2 단계 : Java 환경 설정
시스템에서 Java가 설치된 기본 디렉토리 위치를 가리 키도록 환경 변수 JAVA_HOME을 설정하십시오. 예를 들면
Sr. 아니. | 플랫폼 및 설명 |
---|---|
1 | Windows JAVA_HOME을 C : \ ProgramFiles \ java \ jdk1.7.0_60으로 설정합니다. |
2 | Linux JAVA_HOME 내보내기 = / usr / local / java-current |
Java 컴파일러 위치의 전체 경로를 시스템 경로에 추가하십시오.
Sr. 아니. | 플랫폼 및 설명 |
---|---|
1 | Windows 시스템 변수 PATH의 끝에 문자열 "C : \ Program Files \ Java \ jdk1.7.0_60 \ bin"을 추가합니다. |
2 | Linux 내보내기 PATH = $ PATH : $ JAVA_HOME / bin / |
위에서 설명한대로 명령 프롬프트에서 명령 java 버전을 실행합니다.
3 단계 : Apache Xerces 라이브러리 설치
최신 버전의 Apache Xerces를 다음에서 다운로드하십시오. https://xerces.apache.org/mirrors.cgi"필요한 라이브러리가 Java 프로그램에 링크 될 수있는 폴더에 컨텐츠의 압축을 풉니 다. 파일이 C 드라이브의 xerces-2_11_0 폴더에 수집되었다고 가정 해 보겠습니다.
위 이미지에 강조 표시된대로 5 개의 항아리의 전체 경로를 CLASSPATH에 추가하십시오.
Sr. 아니. | 플랫폼 및 설명 |
---|---|
1 | Windows 사용자 변수 CLASSPATH 끝에 다음 문자열을 추가하십시오. C : \ xerces-2_11_0 \ resolver.jar; C : \ xerces-2_11_0 \ serializer.jar; C : \ xerces-2_11_0 \ xercesImpl.jar; C : \ xerces-2_11_0 \ xercesSamples.jar; C : \ xerces-2_11_0 \ xml-apis.jar; |
2 | Linux 내보내기 CLASSPATH = $ CLASSPATH − /usr/share/xerces-2_11_0\resolver.jar; /usr/share/xerces-2_11_0\serializer.jar; /usr/share/xerces-2_11_0\xercesImpl.jar; /usr/share/xerces-2_11_0\xercesSamples.jar; /usr/share/xerces-2_11_0\xml-apis.jar; |
Apache Xerces2 란 무엇입니까?
Xerces2는 Java 기반 프로세서이며 다음 XML 구문 분석 API 표준을위한 표준 인터페이스 및 구현을 제공합니다.
DOM (문서 개체 모델) 수준 3
SAX (Simple API for XML) 2.0.2
XML 용 스트리밍 API (StAX) 1.0 이벤트 API
JAXP (Java APIs for XML Processing) 1.4
XML 구문 분석이란 무엇입니까?
XML 구문 분석은 XML 문서를 통해 데이터에 액세스하거나 하나 또는 다른 방식으로 데이터를 수정하는 것을 말합니다.
XML 파서 란?
XML 파서는 XML 문서에있는 데이터에 액세스하거나 수정하는 방법을 제공합니다. Java는 XML 문서를 구문 분석하는 여러 옵션을 제공합니다. 다음은 XML 문서를 구문 분석하는 데 일반적으로 사용되는 다양한 유형의 구문 분석기입니다.
Dom Parser − 문서의 전체 내용을로드하고 메모리에 전체 계층 트리를 생성하여 문서를 구문 분석합니다.
SAX Parser− 이벤트 기반 트리거에서 문서를 구문 분석합니다. 전체 문서를 메모리에로드하지 않습니다.
StAX Parser − SAX 구문 분석기와 유사한 방식으로 문서를 구문 분석하지만보다 효율적인 방식으로 구문 분석합니다.
이제 다음 장에서 Apache Xerces 라이브러리를 사용하여 각 파서를 자세히 설명하겠습니다.
문서 개체 모델은 W3C (World Wide Web Consortium)의 공식 권장 사항입니다. 프로그램이 XML 문서의 스타일, 구조 및 컨텐츠에 액세스하고 업데이트 할 수 있도록하는 인터페이스를 정의합니다. DOM을 지원하는 XML 파서는 해당 인터페이스를 구현합니다.
언제 사용합니까?
다음과 같은 경우 DOM 파서를 사용해야합니다.
문서의 구조에 대해 많이 알아야합니다.
문서의 일부를 이동해야합니다 (예를 들어 특정 요소를 정렬 할 수 있음).
문서의 정보를 두 번 이상 사용해야합니다.
당신은 무엇을 얻습니까?
DOM 파서를 사용하여 XML 문서를 구문 분석하면 문서의 모든 요소가 포함 된 트리 구조가 반환됩니다. DOM은 문서의 내용과 구조를 검사하는 데 사용할 수있는 다양한 기능을 제공합니다.
장점
DOM은 문서 구조를 조작하기위한 공통 인터페이스입니다. 디자인 목표 중 하나는 하나의 DOM 호환 파서 용으로 작성된 Java 코드가 변경없이 다른 DOM 호환 파서에서 실행되어야한다는 것입니다.
DOM 인터페이스
DOM은 여러 Java 인터페이스를 정의합니다. 다음은 가장 일반적인 인터페이스입니다.
Node − DOM의 기본 데이터 유형.
Element − 다루게 될 객체의 대부분은 요소입니다.
Attr − 요소의 속성을 나타냅니다.
Text − 요소 또는 속성의 실제 내용.
Document− 전체 XML 문서를 나타냅니다. Document 객체는 종종 DOM 트리라고합니다.
일반적인 DOM 메서드
DOM으로 작업 할 때 자주 사용되는 몇 가지 방법이 있습니다.
Document.getDocumentElement() − 문서의 루트 요소를 반환합니다.
Node.getFirstChild() − 주어진 노드의 첫 번째 자식을 반환합니다.
Node.getLastChild() − 주어진 노드의 마지막 자식을 반환합니다.
Node.getNextSibling() −이 메소드는 주어진 노드의 다음 형제를 반환합니다.
Node.getPreviousSibling() −이 메소드는 주어진 Node의 이전 형제를 반환합니다.
Node.getAttribute(attrName) − 주어진 노드에 대해 요청 된 이름의 속성을 반환합니다.
DOM 사용 단계
다음은 DOM 파서를 사용하여 문서를 구문 분석하는 동안 사용되는 단계입니다.
XML 관련 패키지를 가져옵니다.
DocumentBuilder 만들기
파일 또는 스트림에서 문서 만들기
루트 요소 추출
속성 검토
하위 요소 검토
XML 관련 패키지 가져 오기
import org.w3c.dom.*;
import javax.xml.parsers.*;
import java.io.*;
DocumentBuilder 만들기
DocumentBuilderFactory factory =
DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
파일 또는 스트림에서 문서 만들기
StringBuilder xmlStringBuilder = new StringBuilder();
xmlStringBuilder.append("<?xml version = "1.0"?> <class> </class>");
ByteArrayInputStream input = new ByteArrayInputStream(
xmlStringBuilder.toString().getBytes("UTF-8"));
Document doc = builder.parse(input);
루트 요소 추출
Element root = document.getDocumentElement();
속성 검토
//returns specific attribute
getAttribute("attributeName");
//returns a Map (table) of names/values
getAttributes();
하위 요소 검토
//returns a list of subelements of specified name
getElementsByTagName("subelementName");
//returns a list of all child nodes
getChildNodes();
Demo Example
다음은 파싱해야하는 입력 xml 파일입니다.
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
데모 예
DomParserDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
public class DomParserDemo {
public static void main(String[] args){
try {
File inputFile = new File("input.txt");
DocumentBuilderFactory dbFactory
= DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(inputFile);
doc.getDocumentElement().normalize();
System.out.println("Root element :"
+ doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("student");
System.out.println("----------------------------");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
System.out.println("\nCurrent Element :"
+ nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.println("Student roll no : "
+ eElement.getAttribute("rollno"));
System.out.println("First Name : "
+ eElement
.getElementsByTagName("firstname")
.item(0)
.getTextContent());
System.out.println("Last Name : "
+ eElement
.getElementsByTagName("lastname")
.item(0)
.getTextContent());
System.out.println("Nick Name : "
+ eElement
.getElementsByTagName("nickname")
.item(0)
.getTextContent());
System.out.println("Marks : "
+ eElement
.getElementsByTagName("marks")
.item(0)
.getTextContent());
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
Root element :class
----------------------------
Current Element :student
Student roll no : 393
First Name : Dinkar
Last Name : Kad
Nick Name : Dinkar
Marks : 85
Current Element :student
Student roll no : 493
First Name : Vineet
Last Name : Gupta
Nick Name : Vinni
Marks : 95
Current Element :student
Student roll no : 593
First Name : Jasvir
Last Name : Singh
Nick Name : Jazz
Marks : 90
데모 예
다음은 쿼리해야하는 입력 xml 파일입니다.
<?xml version = "1.0"?>
<cars>
<supercars company = "Ferrari">
<carname type = "formula one">Ferarri 101</carname>
<carname type = "sports car">Ferarri 201</carname>
<carname type = "sports car">Ferarri 301</carname>
</supercars>
<supercars company = "Lamborgini">
<carname>Lamborgini 001</carname>
<carname>Lamborgini 002</carname>
<carname>Lamborgini 003</carname>
</supercars>
<luxurycars company = "Benteley">
<carname>Benteley 1</carname>
<carname>Benteley 2</carname>
<carname>Benteley 3</carname>
</luxurycars>
</cars>
데모 예
QueryXmlFileDemo.java
package com.tutorialspoint.xml;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
import java.io.File;
public class QueryXmlFileDemo {
public static void main(String argv[]) {
try {
File inputFile = new File("input.txt");
DocumentBuilderFactory dbFactory =
DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(inputFile);
doc.getDocumentElement().normalize();
System.out.print("Root element: ");
System.out.println(doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("supercars");
System.out.println("----------------------------");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
System.out.println("\nCurrent Element :");
System.out.print(nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.print("company : ");
System.out.println(eElement.getAttribute("company"));
NodeList carNameList =
eElement.getElementsByTagName("carname");
for (int count = 0;
count < carNameList.getLength(); count++) {
Node node1 = carNameList.item(count);
if (node1.getNodeType() ==
node1.ELEMENT_NODE) {
Element car = (Element) node1;
System.out.print("car name : ");
System.out.println(car.getTextContent());
System.out.print("car type : ");
System.out.println(car.getAttribute("type"));
}
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
Root element :cars
----------------------------
Current Element :supercars
company : Ferrari
car name : Ferarri 101
car type : formula one
car name : Ferarri 201
car type : sports car
car name : Ferarri 301
car type : sports car
Current Element :supercars
company : Lamborgini
car name : Lamborgini 001
car type :
car name : Lamborgini 002
car type :
car name : Lamborgini 003
car type :
데모 예
다음은 우리가 만들어야하는 XML입니다.
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
데모 예
CreateXmlFileDemo.java
package com.tutorialspoint.xml;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Attr;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import java.io.File;
public class CreateXmlFileDemo {
public static void main(String argv[]) {
try {
DocumentBuilderFactory dbFactory =
DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder =
dbFactory.newDocumentBuilder();
Document doc = dBuilder.newDocument();
// root element
Element rootElement = doc.createElement("cars");
doc.appendChild(rootElement);
// supercars element
Element supercar = doc.createElement("supercars");
rootElement.appendChild(supercar);
// setting attribute to element
Attr attr = doc.createAttribute("company");
attr.setValue("Ferrari");
supercar.setAttributeNode(attr);
// carname element
Element carname = doc.createElement("carname");
Attr attrType = doc.createAttribute("type");
attrType.setValue("formula one");
carname.setAttributeNode(attrType);
carname.appendChild(
doc.createTextNode("Ferrari 101"));
supercar.appendChild(carname);
Element carname1 = doc.createElement("carname");
Attr attrType1 = doc.createAttribute("type");
attrType1.setValue("sports");
carname1.setAttributeNode(attrType1);
carname1.appendChild(
doc.createTextNode("Ferrari 202"));
supercar.appendChild(carname1);
// write the content into xml file
TransformerFactory transformerFactory =
TransformerFactory.newInstance();
Transformer transformer =
transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result =
new StreamResult(new File("C:\\cars.xml"));
transformer.transform(source, result);
// Output to console for testing
StreamResult consoleResult =
new StreamResult(System.out);
transformer.transform(source, consoleResult);
} catch (Exception e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
데모 예
다음은 수정해야 할 입력 xml 파일입니다.
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars>
<supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars>
<luxurycars company = "Benteley">
<carname>Benteley 1</carname>
<carname>Benteley 2</carname>
<carname>Benteley 3</carname>
</luxurycars>
</cars>
데모 예
ModifyXmlFileDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class ModifyXmlFileDemo {
public static void main(String argv[]) {
try {
File inputFile = new File("input.txt");
DocumentBuilderFactory docFactory =
DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder =
docFactory.newDocumentBuilder();
Document doc = docBuilder.parse(inputFile);
Node cars = doc.getFirstChild();
Node supercar = doc.getElementsByTagName("supercars").item(0);
// update supercar attribute
NamedNodeMap attr = supercar.getAttributes();
Node nodeAttr = attr.getNamedItem("company");
nodeAttr.setTextContent("Lamborigini");
// loop the supercar child node
NodeList list = supercar.getChildNodes();
for (int temp = 0; temp < list.getLength(); temp++) {
Node node = list.item(temp);
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) node;
if ("carname".equals(eElement.getNodeName())){
if("Ferrari 101".equals(eElement.getTextContent())){
eElement.setTextContent("Lamborigini 001");
}
if("Ferrari 202".equals(eElement.getTextContent()))
eElement.setTextContent("Lamborigini 002");
}
}
}
NodeList childNodes = cars.getChildNodes();
for(int count = 0; count < childNodes.getLength(); count++){
Node node = childNodes.item(count);
if("luxurycars".equals(node.getNodeName()))
cars.removeChild(node);
}
// write the content on console
TransformerFactory transformerFactory =
TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
System.out.println("-----------Modified File-----------");
StreamResult consoleResult = new StreamResult(System.out);
transformer.transform(source, consoleResult);
} catch (Exception e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
-----------Modified File-----------
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars>
<supercars company = "Lamborigini">
<carname type = "formula one">Lamborigini 001</carname>
<carname type = "sports">Lamborigini 002</carname>
</supercars></cars>
SAX (XML 용 단순 API)는 xml 문서에 대한 이벤트 기반 파서입니다. DOM 구문 분석기와 달리 SAX 구문 분석기는 구문 분석 트리를 생성하지 않습니다. SAX는 XML 용 스트리밍 인터페이스입니다. 즉, SAX를 사용하는 응용 프로그램은 처리중인 XML 문서 (요소 및 속성)에 대한 이벤트 알림을 문서 맨 위에서 시작하여 닫을 때까지 순차적으로 수신합니다. ROOT 요소.
XML 문서를 위에서 아래로 읽고 올바른 형식의 XML 문서를 구성하는 토큰을 인식합니다.
토큰은 문서에 표시된 것과 동일한 순서로 처리됩니다.
구문 분석기가 발생한 토큰의 특성 인 애플리케이션 프로그램을보고합니다.
응용 프로그램은 파서에 등록해야하는 "이벤트"처리기를 제공합니다.
토큰이 식별되면 핸들러의 콜백 메소드가 관련 정보와 함께 호출됩니다.
언제 사용합니까?
다음과 같은 경우 SAX 파서를 사용해야합니다.
XML 문서를 위에서 아래로 선형 방식으로 처리 할 수 있습니다.
문서가 깊게 중첩되지 않았습니다.
DOM 트리가 많은 메모리를 사용하는 매우 큰 XML 문서를 처리하고 있습니다. 일반적인 DOM 구현은 10 바이트의 메모리를 사용하여 1 바이트의 XML을 나타냅니다.
해결해야 할 문제는 XML 문서의 일부에만 관련됩니다.
데이터는 파서가 보는 즉시 사용할 수 있으므로 SAX는 스트림을 통해 도착하는 XML 문서에 적합합니다.
SAX의 단점
XML 문서는 포워드 전용 방식으로 처리되기 때문에 임의의 액세스 권한이 없습니다.
파서가 본 데이터를 추적하거나 항목의 순서를 변경해야하는 경우 코드를 작성하고 데이터를 직접 저장해야합니다.
ContentHandler 인터페이스
이 인터페이스는 SAX 파서가 본 XML 문서의 구성 요소를 응용 프로그램에 알리기 위해 사용하는 콜백 메서드를 지정합니다.
void startDocument() − 문서 시작 부분에 호출됩니다.
void endDocument() − 문서 시작 부분에 호출됩니다.
void startElement(String uri, String localName, String qName, Attributes atts) − 요소의 시작 부분에서 호출됩니다.
void endElement(String uri, String localName,String qName) − 요소의 끝에서 호출됩니다.
void characters(char[] ch, int start, int length) − 문자 데이터가 발견되면 호출됩니다.
void ignorableWhitespace( char[] ch, int start, int length) − DTD가 있고 무시할 수있는 공백이있을 때 호출됩니다.
void processingInstruction(String target, String data) − 처리 명령이 인식되면 호출됩니다.
void setDocumentLocator(Locator locator)) − 문서에서 위치를 식별하는 데 사용할 수있는 로케이터를 제공합니다.
void skippedEntity(String name) − 해결되지 않은 개체가 발견되면 호출됩니다.
void startPrefixMapping(String prefix, String uri) − 새로운 네임 스페이스 매핑이 정의 될 때 호출됩니다.
void endPrefixMapping(String prefix) − 네임 스페이스 정의가 범위를 끝낼 때 호출됩니다.
속성 인터페이스
이 인터페이스는 요소에 연결된 속성을 처리하는 방법을 지정합니다.
int getLength() − 속성 수를 반환합니다.
String getQName(int index)
String getValue(int index)
String getValue(String qname)
데모 예
다음은 파싱해야하는 입력 xml 파일입니다.
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
UserHandler.java
package com.tutorialspoint.xml;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
String rollNo = attributes.getValue("rollno");
System.out.println("Roll No : " + rollNo);
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri,
String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName) {
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
SAXParserDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class SAXParserDemo {
public static void main(String[] args){
try {
File inputFile = new File("input.txt");
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
UserHandler userhandler = new UserHandler();
saxParser.parse(inputFile, userhandler);
} catch (Exception e) {
e.printStackTrace();
}
}
}
class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
String rollNo = attributes.getValue("rollno");
System.out.println("Roll No : " + rollNo);
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri,
String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName) {
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
Roll No : 393
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element :student
Roll No : 493
First Name: Vineet
Last Name: Gupta
Nick Name: Vinni
Marks: 95
End Element :student
Roll No : 593
First Name: Jasvir
Last Name: Singh
Nick Name: Jazz
Marks: 90
End Element :student
데모 예
다음은 롤 번호를 쿼리하는 데 필요한 입력 텍스트 파일입니다. 393 −
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
UserHandler.java
package com.tutorialspoint.xml;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
String rollNo = null;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
rollNo = attributes.getValue("rollno");
}
if(("393").equals(rollNo) && qName.equalsIgnoreCase("student")){
System.out.println("Start Element :" + qName);
}
if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri, String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
if(("393").equals(rollNo)
&& qName.equalsIgnoreCase("student"))
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName && ("393").equals(rollNo)) {
//age element, set Employee age
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName && ("393").equals(rollNo)) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName && ("393").equals(rollNo)) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks && ("393").equals(rollNo)) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
SAXQueryDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class SAXQueryDemo {
public static void main(String[] args){
try {
File inputFile = new File("input.txt");
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
UserHandler userhandler = new UserHandler();
saxParser.parse(inputFile, userhandler);
} catch (Exception e) {
e.printStackTrace();
}
}
}
class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
String rollNo = null;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
rollNo = attributes.getValue("rollno");
}
if(("393").equals(rollNo) &&
qName.equalsIgnoreCase("student")){
System.out.println("Start Element :" + qName);
}
if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri,
String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
if(("393").equals(rollNo)
&& qName.equalsIgnoreCase("student"))
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName && ("393").equals(rollNo)) {
//age element, set Employee age
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName && ("393").equals(rollNo)) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName && ("393").equals(rollNo)) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks && ("393").equals(rollNo)) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
Start Element :student
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element :student
SAX 구문 분석기를 사용하는 것보다 XML 작성에 StAX 구문 분석기를 사용하는 것이 좋습니다. Java StAX Parser 섹션을 참조하십시오.
데모 예
다음은 추가하여 수정해야하는 입력 xml 파일입니다. <Result>Pass<Result/> 의 끝에서 </marks> tag.
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
SAXModifyDemo.java
package com.tutorialspoint.xml;
import java.io.*;
import org.xml.sax.*;
import javax.xml.parsers.*;
import org.xml.sax.helpers.DefaultHandler;
public class SAXModifyDemo extends DefaultHandler {
static String displayText[] = new String[1000];
static int numberLines = 0;
static String indentation = "";
public static void main(String args[]) {
try {
File inputFile = new File("input.txt");
SAXParserFactory factory =
SAXParserFactory.newInstance();
SAXModifyDemo obj = new SAXModifyDemo();
obj.childLoop(inputFile);
FileWriter filewriter = new FileWriter("newfile.xml");
for(int loopIndex = 0; loopIndex < numberLines; loopIndex++){
filewriter.write(displayText[loopIndex].toCharArray());
filewriter.write('\n');
System.out.println(displayText[loopIndex].toString());
}
filewriter.close();
} catch (Exception e) {
e.printStackTrace(System.err);
}
}
public void childLoop(File input){
DefaultHandler handler = this;
SAXParserFactory factory = SAXParserFactory.newInstance();
try {
SAXParser saxParser = factory.newSAXParser();
saxParser.parse(input, handler);
} catch (Throwable t) {}
}
public void startDocument() {
displayText[numberLines] = indentation;
displayText[numberLines] += "<?xml version=\"1.0\" encoding=\""+
"UTF-8" + "\"?>";
numberLines++;
}
public void processingInstruction(String target, String data) {
displayText[numberLines] = indentation;
displayText[numberLines] += "<?";
displayText[numberLines] += target;
if (data != null && data.length() > 0) {
displayText[numberLines] += ' ';
displayText[numberLines] += data;
}
displayText[numberLines] += "?>";
numberLines++;
}
public void startElement(String uri, String localName,
String qualifiedName, Attributes attributes) {
displayText[numberLines] = indentation;
indentation += " ";
displayText[numberLines] += '<';
displayText[numberLines] += qualifiedName;
if (attributes != null) {
int numberAttributes = attributes.getLength();
for (int loopIndex = 0; loopIndex < numberAttributes;
loopIndex++){
displayText[numberLines] += ' ';
displayText[numberLines] += attributes.getQName(loopIndex);
displayText[numberLines] += "=\"";
displayText[numberLines] += attributes.getValue(loopIndex);
displayText[numberLines] += '"';
}
}
displayText[numberLines] += '>';
numberLines++;
}
public void characters(char characters[], int start, int length) {
String characterData = (new String(characters, start, length)).trim();
if(characterData.indexOf("\n") < 0 && characterData.length() > 0) {
displayText[numberLines] = indentation;
displayText[numberLines] += characterData;
numberLines++;
}
}
public void endElement(String uri, String localName, String qualifiedName) {
indentation = indentation.substring(0, indentation.length() - 4);
displayText[numberLines] = indentation;
displayText[numberLines] += "</";
displayText[numberLines] += qualifiedName;
displayText[numberLines] += '>';
numberLines++;
if (qualifiedName.equals("marks")) {
startElement("", "Result", "Result", null);
characters("Pass".toCharArray(), 0, "Pass".length());
endElement("", "Result", "Result");
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
<?xml version = "1.0" encoding = "UTF-8"?>
<class>
<student rollno = "393">
<firstname>
Dinkar
</firstname>
<lastname>
Kad
</lastname>
<nickname>
Dinkar
</nickname>
<marks>
85
</marks>
<Result>
Pass
</Result>
</student>
<student rollno = "493">
<firstname>
Vineet
</firstname>
<lastname>
Gupta
</lastname>
<nickname>
Vinni
</nickname>
<marks>
95
</marks>
<Result>
Pass
</Result>
</student>
<student rollno = "593">
<firstname>
Jasvir
</firstname>
<lastname>
Singh
</lastname>
<nickname>
Jazz
</nickname>
<marks>
90
</marks>
<Result>
Pass
</Result>
</student>
</class>
StAX는 SAX 파서와 유사한 방식으로 XML 문서를 구문 분석하는 JAVA 기반 API입니다. 그러나 두 API 사이에는 두 가지 주요 차이점이 있습니다.
StAX는 PULL API 인 반면 SAX는 PUSH API입니다. StAX 파서의 경우 클라이언트 응용 프로그램은 필요할 때마다 XML에서 정보를 가져 오도록 StAX 파서에게 요청해야하지만 SAX 파서의 경우 SAX 파서가 클라이언트 응용 프로그램에 정보를 알릴 때 클라이언트 응용 프로그램이 정보를 가져와야합니다. 사용할 수 있습니다.
StAX API는 XML 문서를 읽고 쓸 수 있습니다. SAX API를 사용하면 xml은 읽기만 가능합니다.
다음은 StAX API의 기능입니다-
XML 문서를 위에서 아래로 읽고 올바른 형식의 XML 문서를 구성하는 토큰을 인식합니다.
토큰은 문서에 표시된 것과 동일한 순서로 처리됩니다.
구문 분석기가 발생했을 때 발견 한 토큰의 특성에 대해 애플리케이션 프로그램을보고합니다.
응용 프로그램은 반복자 역할을하고 필요한 정보를 얻기 위해 이벤트를 반복하는 "이벤트"판독기를 제공합니다. 사용 가능한 또 다른 판독기는 xml 노드에 대한 포인터 역할을하는 "커서"판독기입니다.
이벤트가 식별되면 이벤트 개체에서 xml 요소를 검색하고 추가로 처리 할 수 있습니다.
언제 사용합니까?
다음과 같은 경우 StAX 파서를 사용해야합니다.
XML 문서를 위에서 아래로 선형 방식으로 처리 할 수 있습니다.
문서가 깊게 중첩되지 않았습니다.
DOM 트리가 너무 많은 메모리를 사용하는 매우 큰 XML 문서를 처리하고 있습니다. 일반적인 DOM 구현은 10 바이트의 메모리를 사용하여 1 바이트의 XML을 나타냅니다.
해결해야 할 문제는 XML 문서의 일부에만 관련됩니다.
데이터는 파서가 보는 즉시 사용할 수 있으므로 StAX는 스트림을 통해 도착하는 XML 문서에 적합합니다.
SAX의 단점
XML 문서는 순방향 전용 방식으로 처리되기 때문에 임의의 액세스가 없습니다.
파서가 본 데이터를 추적하거나 항목의 순서를 변경해야하는 경우 코드를 작성하고 데이터를 직접 저장해야합니다.
XMLEventReader 클래스
이 클래스는 XML 문서를 구문 분석하는 동안 발생하는 이벤트를 반복하는 데 사용할 수있는 이벤트의 반복자를 제공합니다.
StartElement asStartElement() − 요소의 값과 속성을 검색하는 데 사용됩니다.
EndElement asEndElement() − 요소의 끝에서 호출됩니다.
Characters asCharacters() − CDATA, 공백 등의 문자를 얻는 데 사용할 수 있습니다.
XMLEventWriter 클래스
이 인터페이스는 이벤트 생성 방법을 지정합니다.
add(Event event) − XML에 요소가 포함 된 이벤트를 추가합니다.
XMLStreamReader 클래스
이 클래스는 XML 문서를 구문 분석하는 동안 발생하는 이벤트를 반복하는 데 사용할 수있는 이벤트의 반복자를 제공합니다.
int next() − 다음 이벤트 검색에 사용됩니다.
boolean hasNext() − 추가 이벤트 존재 여부 확인에 사용
String getText() − 요소의 텍스트를 가져 오는 데 사용
String getLocalName() − 요소의 이름을 얻는 데 사용
XMLStreamWriter 클래스
이 인터페이스는 이벤트 생성 방법을 지정합니다.
writeStartElement(String localName) − 주어진 이름의 시작 요소를 추가합니다.
writeEndElement(String localName) − 주어진 이름의 끝 요소를 추가합니다.
writeAttribute(String localName, String value) − 요소에 속성을 씁니다.
데모 예
다음은 파싱해야하는 입력 xml 파일입니다.
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
StAXParserDemo.java
package com.tutorialspoint.xml;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.Iterator;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.Characters;
import javax.xml.stream.events.EndElement;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
public class StAXParserDemo {
public static void main(String[] args) {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
try {
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader eventReader =
factory.createXMLEventReader(new FileReader("input.txt"));
while(eventReader.hasNext()){
XMLEvent event = eventReader.nextEvent();
switch(event.getEventType()){
case XMLStreamConstants.START_ELEMENT:
StartElement startElement = event.asStartElement();
String qName = startElement.getName().getLocalPart();
if (qName.equalsIgnoreCase("student")) {
System.out.println("Start Element : student");
Iterator<Attribute> attributes = startElement.getAttributes();
String rollNo = attributes.next().getValue();
System.out.println("Roll No : " + rollNo);
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
break;
case XMLStreamConstants.CHARACTERS:
Characters characters = event.asCharacters();
if(bFirstName){
System.out.println("First Name: " + characters.getData());
bFirstName = false;
}
if(bLastName){
System.out.println("Last Name: " + characters.getData());
bLastName = false;
}
if(bNickName){
System.out.println("Nick Name: " + characters.getData());
bNickName = false;
}
if(bMarks){
System.out.println("Marks: " + characters.getData());
bMarks = false;
}
break;
case XMLStreamConstants.END_ELEMENT:
EndElement endElement = event.asEndElement();
if(endElement.getName().getLocalPart().equalsIgnoreCase("student")){
System.out.println("End Element : student");
System.out.println();
}
break;
}
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
Start Element : student
Roll No : 393
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element : student
Start Element : student
Roll No : 493
First Name: Vineet
Last Name: Gupta
Nick Name: Vinni
Marks: 95
End Element : student
Start Element : student
Roll No : 593
First Name: Jasvir
Last Name: Singh
Nick Name: Jazz
Marks: 90
End Element : student
데모 예
다음은 파싱해야하는 입력 xml 파일입니다.
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
StAXParserDemo.java
package com.tutorialspoint.xml;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.Iterator;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.Characters;
import javax.xml.stream.events.EndElement;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
public class StAXQueryDemo {
public static void main(String[] args) {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
boolean isRequestRollNo = false;
try {
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader eventReader = factory.createXMLEventReader(
new FileReader("input.txt"));
String requestedRollNo = "393";
while(eventReader.hasNext()){
XMLEvent event = eventReader.nextEvent();
switch(event.getEventType()){
case XMLStreamConstants.START_ELEMENT:
StartElement startElement = event.asStartElement();
String qName = startElement.getName().getLocalPart();
if (qName.equalsIgnoreCase("student")) {
Iterator<Attribute> attributes = startElement.getAttributes();
String rollNo = attributes.next().getValue();
if(rollNo.equalsIgnoreCase(requestedRollNo)){
System.out.println("Start Element : student");
System.out.println("Roll No : " + rollNo);
isRequestRollNo = true;
}
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
break;
case XMLStreamConstants.CHARACTERS:
Characters characters = event.asCharacters();
if(bFirstName && isRequestRollNo){
System.out.println("First Name: " + characters.getData());
bFirstName = false;
}
if(bLastName && isRequestRollNo){
System.out.println("Last Name: " + characters.getData());
bLastName = false;
}
if(bNickName && isRequestRollNo){
System.out.println("Nick Name: " + characters.getData());
bNickName = false;
}
if(bMarks && isRequestRollNo){
System.out.println("Marks: " + characters.getData());
bMarks = false;
}
break;
case XMLStreamConstants.END_ELEMENT:
EndElement endElement = event.asEndElement();
if(endElement.getName().getLocalPart().equalsIgnoreCase("student") && isRequestRollNo){
System.out.println("End Element : student");
System.out.println();
isRequestRollNo = false;
}
break;
}
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
Start Element : student
Roll No : 393
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element : student
데모 예
Here is the XML we need to create −
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
데모 예
StAXCreateXMLDemo.java
package com.tutorialspoint.xml;
import java.io.IOException;
import java.io.StringWriter;
import javax.xml.stream.XMLOutputFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
public class StAXCreateXMLDemo {
public static void main(String[] args) {
try {
StringWriter stringWriter = new StringWriter();
XMLOutputFactory xMLOutputFactory = XMLOutputFactory.newInstance();
XMLStreamWriter xMLStreamWriter = xMLOutputFactory.createXMLStreamWriter(stringWriter);
xMLStreamWriter.writeStartDocument();
xMLStreamWriter.writeStartElement("cars");
xMLStreamWriter.writeStartElement("supercars");
xMLStreamWriter.writeAttribute("company", "Ferrari");
xMLStreamWriter.writeStartElement("carname");
xMLStreamWriter.writeAttribute("type", "formula one");
xMLStreamWriter.writeCharacters("Ferrari 101");
xMLStreamWriter.writeEndElement();
xMLStreamWriter.writeStartElement("carname");
xMLStreamWriter.writeAttribute("type", "sports");
xMLStreamWriter.writeCharacters("Ferrari 202");
xMLStreamWriter.writeEndElement();
xMLStreamWriter.writeEndElement();
xMLStreamWriter.writeEndDocument();
xMLStreamWriter.flush();
xMLStreamWriter.close();
String xmlString = stringWriter.getBuffer().toString();
stringWriter.close();
System.out.println(xmlString);
} catch (XMLStreamException e) {
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
데모 예
이 예제를 실행하려면 애플리케이션의 클래스 경로에 jdom.jar이 있어야합니다. jdom-2.0.5.zip을 다운로드 합니다.
수정해야 할 XML은 다음과 같습니다.
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
데모 예
StAXModifyDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.JDOMException;
import org.jdom2.input.SAXBuilder;
import org.jdom2.output.Format;
import org.jdom2.output.XMLOutputter;
public class StAXModifyDemo {
public static void main(String[] args) {
try {
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader eventReader =
factory.createXMLEventReader(
new FileReader("input.txt"));
SAXBuilder saxBuilder = new SAXBuilder();
Document document = saxBuilder.build(new File("input.txt"));
Element rootElement = document.getRootElement();
List<Element> studentElements = rootElement.getChildren("student");
while(eventReader.hasNext()){
XMLEvent event = eventReader.nextEvent();
switch(event.getEventType()){
case XMLStreamConstants.START_ELEMENT:
StartElement startElement = event.asStartElement();
String qName = startElement.getName().getLocalPart();
if (qName.equalsIgnoreCase("student")) {
Iterator<Attribute> attributes = startElement.getAttributes();
String rollNo = attributes.next().getValue();
if(rollNo.equalsIgnoreCase("393")){
//get the student with roll no 393
for(int i=0;i < studentElements.size();i++){
Element studentElement = studentElements.get(i);
if(studentElement.getAttribute("rollno").getValue().equalsIgnoreCase("393")){
studentElement.removeChild("marks");
studentElement.addContent(new Element("marks").setText("80"));
}
}
}
}
break;
}
}
XMLOutputter xmlOutput = new XMLOutputter();
// display xml
xmlOutput.setFormat(Format.getPrettyFormat());
xmlOutput.output(document, System.out);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
} catch (JDOMException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
위의 프로그램은 다음 결과를 생성합니다-
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>80</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>