JDOM은 XML 문서를 보다 편리하게 읽고 수정하고 생성할 수 있는 매우 뛰어난 Java XML API를 제공합니다. JDOM은 또한 사용자가 SAX, DOM, STAX 이벤트 구문 분석 및 STAX 스트림 구문 분석에서 특정 구현을 선택할 수 있도록 래퍼 클래스를 제공합니다.
이 튜토리얼에서는 JDOM을 사용하여 XML 파일 정보를 읽고 이를 Java 객체로 변환하는 방법을 배웁니다.
JDOM은 표준 JDK의 일부가 아니므로 JDOM을 사용하려면 공식 웹사이트에서 JDOM 바이너리 패키지를 다운로드한 후 프로젝트의 클래스 경로에 JDOM Jar 패키지를 추가해야 합니다.
JDOM은 기본 XML 구문 분석 API를 선택할 수 있도록 래퍼 클래스를 제공합니다. 이는 JDOM 문서 개체를 얻는 데 사용할 수 있는 네 가지 중요한 클래스를 제공합니다. JDOM 문서 객체는 루트 요소, 하위 요소 목록, 속성 값 등을 가져오는 매우 유용한 방법을 제공합니다.
JDOM의 중요한 클래스: org.jdom2.input.DOMBuilder:
DOM 구문 분석 메커니즘을 사용하여 XML을 구문 분석하고 이를 JDOM 문서 객체로 변환합니다. org.jdom2.input.SAXBuilder:
SAX 구문 분석 메커니즘을 사용하여 XML을 구문 분석하고 이를 JDOM 문서로 변환합니다. org.jdom2.input.StAXEventBuilder
, org.jdom2.input.StAXStreamBuilder
의 기능은 앞의 두 기능과 유사하므로 다시 설명하지 않겠습니다. org.jdom2.Document
JDOM 문서 개체는 루트 요소를 가져오고 요소 내용을 읽거나 수정하는 등의 유용한 방법을 제공합니다. 이를 사용하여 XML의 루트 요소를 가져옵니다. org.jdom2.Document
은 하위 요소 컬렉션 가져오기, 하위 요소 값 가져오기, 속성 값 가져오기 및 기타 작업에 유용한 방법을 제공합니다.
다음으로 케이스 프로그램을 사용하여 XML 파일을 읽고 Java 객체를 생성합니다.
employees.xml
<?xml version="1.0" encoding="UTF-8"?><Employees> <Employee id="1"> <age>29</age> <name>Pankaj</name> <gender>Male</gender> <role>Java Developer</role> </Employee> <Employee id="2"> <age>35</age> <name>Lisa</name> <gender>Female</gender> <role>CEO</role> </Employee> <Employee id="3"> <age>40</age> <name>Tom</name> <gender>Male</gender> <role>Manager</role> </Employee></Employees>
이 xml 파일은 직원 정보를 저장하기 위해 Employee 클래스를 사용합니다.
package com.journaldev.xml;public class Employee { private int id; private String name; private String gender; private int age; private String role; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getRole() { return role; } public void setRole(String role) { this.role = role; } @Override public String toString() { return "Employee:: ID="+this.id+" Name=" + this.name + " Age=" + this.age + " Gender=" + this.gender + " Role=" + this.role; } }
그런 다음 DOMBuilder를 사용하여 테스트 프로그램에서 XML 파일을 읽고 Employee 개체 컬렉션을 생성합니다.
JDOMXMLReader.java
package com.journaldev.xml.jdom; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.util.ArrayList; import java.util.List; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import javax.xml.stream.XMLEventReader; import javax.xml.stream.XMLInputFactory; import javax.xml.stream.XMLStreamException; import javax.xml.stream.XMLStreamReader; import org.jdom2.Element; import org.jdom2.JDOMException; import org.jdom2.input.DOMBuilder; import org.jdom2.input.SAXBuilder; import org.jdom2.input.StAXEventBuilder; import org.jdom2.input.StAXStreamBuilder; import org.w3c.dom.Document; import org.xml.sax.SAXException; import com.journaldev.xml.Employee; public class JDOMXMLReader { public static void main(String[] args) { final String fileName = "/Users/pankaj/employees.xml"; org.jdom2.Document jdomDoc; try { //we can create JDOM Document from DOM, SAX and STAX Parser Builder classes jdomDoc = useDOMParser(fileName); Element root = jdomDoc.getRootElement(); List<Element> empListElements = root.getChildren("Employee"); List<Employee> empList = new ArrayList<>(); for (Element empElement : empListElements) { Employee emp = new Employee(); emp.setId(Integer.parseInt(empElement.getAttributeValue("id"))); emp.setAge(Integer.parseInt(empElement.getChildText("age"))); emp.setName(empElement.getChildText("name")); emp.setRole(empElement.getChildText("role")); emp.setGender(empElement.getChildText("gender")); empList.add(emp); } //lets print Employees list information for (Employee emp : empList) System.out.println(emp); } catch (Exception e) { e.printStackTrace(); } } //Get JDOM document from DOM Parser private static org.jdom2.Document useDOMParser(String fileName) throws ParserConfigurationException, SAXException, IOException { //creating DOM Document DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder dBuilder; dBuilder = dbFactory.newDocumentBuilder(); Document doc = dBuilder.parse(new File(fileName)); DOMBuilder domBuilder = new DOMBuilder(); return domBuilder.build(doc); } }
보시다시피 여기서는 DOM 구문 분석 래퍼 클래스를 사용하여 JDOM Document 객체를 얻습니다.
프로그램 출력 실행:
Employee:: ID=1 Name=Pankaj Age=29 Gender=Male Role=Java DeveloperEmployee:: ID=2 Name=Lisa Age=35 Gender=Female Role=CEOEmployee:: ID=3 Name=Tom Age=40 Gender=Male Role=Manager
SAX 및 STAX 구문 분석 메커니즘을 사용하여 완료할 수도 있습니다.
/Get JDOM document from SAX Parserprivate static org.jdom2.Document useSAXParser(String fileName) throws JDOMException, IOException { SAXBuilder saxBuilder = new SAXBuilder(); return saxBuilder.build(new File(fileName)); } //Get JDOM Document from STAX Stream Parser or STAX Event Parserprivate static org.jdom2. Document useSTAXParser(String fileName, String type) throws FileNotFoundException, XMLStreamException, JDOMException{ if(type.equalsIgnoreCase("stream")){ StAXStreamBuilder staxBuilder = new StAXStreamBuilder(); XMLInputFactory xmlInputFactory = XMLInputFactory.newInstance(); XMLStreamReader xmlStreamReader = xmlInputFactory.createXMLStreamReader(new FileInputStream(fileName)); return staxBuilder.build(xmlStreamReader); } StAXEventBuilder staxBuilder = new StAXEventBuilder(); XMLInputFactory xmlInputFactory = XMLInputFactory.newInstance(); XMLEventReader xmlEventReader = xmlInputFactory.createXMLEventReader(new FileInputStream(fileName)); return staxBuilder.build(xmlEventReader); }
프로그램을 실행하면 동일한 출력입니다. 왜냐하면 우리는 단지 다른 래퍼 클래스를 사용하지만 얻은 JDOM 문서 객체는 동일하기 때문입니다.
JDOM을 사용하면 처리 코드를 변경하지 않고도 기본 구문 분석 메커니즘을 쉽게 전환할 수 있다는 장점이 있습니다.
JDOM은 XML 문서를 보다 편리하게 읽고 수정하고 생성할 수 있는 매우 뛰어난 Java XML API를 제공합니다. JDOM은 또한 사용자가 SAX, DOM, STAX 이벤트 구문 분석 및 STAX 스트림 구문 분석에서 특정 구현을 선택할 수 있도록 래퍼 클래스를 제공합니다.
이 튜토리얼에서는 JDOM을 사용하여 XML 파일 정보를 읽고 이를 Java 객체로 변환하는 방법을 배웁니다.
JDOM은 표준 JDK의 일부가 아니므로 JDOM을 사용하려면 공식 웹사이트에서 JDOM 바이너리 패키지를 다운로드한 후 프로젝트의 클래스 경로에 JDOM Jar 패키지를 추가해야 합니다.
JDOM은 기본 XML 구문 분석 API를 선택할 수 있도록 래퍼 클래스를 제공합니다. 이는 JDOM 문서 개체를 얻는 데 사용할 수 있는 네 가지 중요한 클래스를 제공합니다. JDOM 문서 객체는 루트 요소, 하위 요소 목록, 속성 값 등을 가져오는 매우 유용한 방법을 제공합니다.
JDOM의 중요한 클래스: org.jdom2.input.DOMBuilder:
DOM 구문 분석 메커니즘을 사용하여 XML을 구문 분석하고 이를 JDOM 문서 객체로 변환합니다. org.jdom2.input.SAXBuilder:
SAX 구문 분석 메커니즘을 사용하여 XML을 구문 분석하고 이를 JDOM 문서로 변환합니다. org.jdom2.input.StAXEventBuilder
, org.jdom2.input.StAXStreamBuilder
의 기능은 앞의 두 기능과 유사하므로 다시 설명하지 않겠습니다. org.jdom2.Document
JDOM 문서 개체는 루트 요소를 가져오고 요소 내용을 읽거나 수정하는 등의 유용한 방법을 제공합니다. 이를 사용하여 XML의 루트 요소를 가져옵니다. org.jdom2.Document
은 하위 요소 컬렉션 가져오기, 하위 요소 값 가져오기, 속성 값 가져오기 및 기타 작업에 유용한 방법을 제공합니다.
다음으로 케이스 프로그램을 사용하여 XML 파일을 읽고 Java 객체를 생성합니다.
employees.xml
<?xml version="1.0" encoding="UTF-8"?><Employees> <Employee id="1"> <age>29</age> <name>Pankaj</name> <gender>Male</gender> <role>Java Developer</role> </Employee> <Employee id="2"> <age>35</age> <name>Lisa</name> <gender>Female</gender> <role>CEO</role> </Employee> <Employee id="3"> <age>40</age> <name>Tom</name> <gender>Male</gender> <role>Manager</role> </Employee></Employees>
이 xml 파일은 직원 정보를 저장하기 위해 Employee 클래스를 사용합니다.
package com.journaldev.xml; public class Employee { private int id; private String name; private String gender; private int age; private String role; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getRole() { return role; } public void setRole(String role) { this.role = role; } @Override public String toString() { return "Employee:: ID="+this.id+" Name=" + this.name + " Age=" + this.age + " Gender=" + this.gender + " Role=" + this.role; } }
그런 다음 DOMBuilder를 사용하여 테스트 프로그램에서 XML 파일을 읽고 Employee 개체 컬렉션을 생성합니다.
JDOMXMLReader.java
package com.journaldev.xml.jdom; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException;import java.util.ArrayList; import java.util.List; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import javax.xml.stream.XMLEventReader; import javax.xml.stream.XMLInputFactory; import javax.xml.stream.XMLStreamException; import javax.xml.stream.XMLStreamReader; import org.jdom2.Element;import org.jdom2.JDOMException; import org.jdom2.input.DOMBuilder; import org.jdom2.input.SAXBuilder; import org.jdom2.input.StAXEventBuilder; import org.jdom2.input.StAXStreamBuilder; import org.w3c.dom.Document; import org.xml.sax.SAXException; import com.journaldev.xml.Employee; public class JDOMXMLReader { public static void main(String[] args) { final String fileName = "/Users/pankaj/employees.xml"; org.jdom2.Document jdomDoc; try { //we can create JDOM Document from DOM, SAX and STAX Parser Builder classes jdomDoc = useDOMParser(fileName); Element root = jdomDoc.getRootElement(); List<Element> empListElements = root.getChildren("Employee"); List<Employee> empList = new ArrayList<>(); for (Element empElement : empListElements) { Employee emp = new Employee(); emp.setId(Integer.parseInt(empElement.getAttributeValue("id"))); emp.setAge(Integer.parseInt(empElement.getChildText("age"))); emp.setName(empElement.getChildText("name")); emp.setRole(empElement.getChildText("role")); emp.setGender(empElement.getChildText("gender")); empList.add(emp); } //lets print Employees list information for (Employee emp : empList) System.out.println(emp); } catch (Exception e) { e.printStackTrace(); } } //Get JDOM document from DOM Parser private static org.jdom2.Document useDOMParser(String fileName) throws ParserConfigurationException, SAXException, IOException { //creating DOM Document DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder dBuilder; dBuilder = dbFactory.newDocumentBuilder(); Document doc = dBuilder.parse(new File(fileName)); DOMBuilder domBuilder = new DOMBuilder(); return domBuilder.build(doc); } }
보시다시피 여기서는 DOM 구문 분석 래퍼 클래스를 사용하여 JDOM Document 객체를 얻습니다.
프로그램 출력 실행:
Employee:: ID=1 Name=Pankaj Age=29 Gender=Male Role=Java DeveloperEmployee:: ID=2 Name=Lisa Age=35 Gender=Female Role=CEOEmployee:: ID=3 Name=Tom Age=40 Gender=Male Role=Manager
SAX 및 STAX 구문 분석 메커니즘을 사용하여 완료할 수도 있습니다.
/Get JDOM document from SAX Parserprivate static org.jdom2.Document useSAXParser(String fileName) throws JDOMException, IOException { SAXBuilder saxBuilder = new SAXBuilder(); return saxBuilder.build(new File(fileName)); } //Get JDOM Document from STAX Stream Parser or STAX Event Parserprivate static org.jdom2.Document useSTAXParser(String fileName, String type) throws FileNotFoundException, XMLStreamException, JDOMException{ if(type.equalsIgnoreCase("stream")){ StAXStreamBuilder staxBuilder = new StAXStreamBuilder(); XMLInputFactory xmlInputFactory = XMLInputFactory.newInstance(); XMLStreamReader xmlStreamReader = xmlInputFactory.createXMLStreamReader(new FileInputStream(fileName)); return staxBuilder.build(xmlStreamReader); } StAXEventBuilder staxBuilder = new StAXEventBuilder(); XMLInputFactory xmlInputFactory = XMLInputFactory.newInstance(); XMLEventReader xmlEventReader = xmlInputFactory.createXMLEventReader(new FileInputStream(fileName)); return staxBuilder.build(xmlEventReader); }
프로그램을 실행하면 동일한 출력입니다. 왜냐하면 우리는 단지 다른 래퍼 클래스를 사용하지만 얻은 JDOM 문서 객체는 동일하기 때문입니다.
JDOM을 사용하면 처리 코드를 변경하지 않고도 기본 구문 분석 메커니즘을 쉽게 전환할 수 있다는 장점이 있습니다.
위 내용은 JDOM을 사용하여 XML 파일을 구문 분석하는 Java&Xml 튜토리얼(6)의 내용입니다. 자세한 내용은 PHP 중국어 웹사이트(www.php.cn)를 참고하세요!