JAVA解析XML通常有两种方式:DOM和SAX
DOM: Document Object Model (文档对象模型)
DOM的特性:
定义一组Java接口,基于对象,与语言和平台无关将XML文档表示为树,在内存中解析和存储XML文档,允许随机访问文档的不同部分。
DOM解析XMLDOM的优点,由于树在内存中是持久的,因此可以修改后更新。它还可以在任何时候在树中上下导航,API使用起来也较简单。
解析步骤:
1、创建解析器工厂对象
DocumentBuilderFactory builder = DocumentBuilderFactory.newlnstance();
2、创建解析器对象
DocumentBuilder db = builder.newDocumentBuilder();
3、读取文件到内存
db.parse(" person.xml");
4、从内存中读取数据
NodeList node_ person = doc.getElementsByTagName("person");
特点:
基于树型结构,通过解析器一次性把文档加载到内存中,所以会比较占用内存,可以随机访问,更加灵活,更适合在web开发中使用。
代码示例:
package com.booy;
import org.junit.jupiter.api.Test;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.Arrays;
public class DOMDemo {
@Test
public void domParser(){
//创建一个解析器工厂对象
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
//创建一个解析器对象
try {
DocumentBuilder documentBuilder = dbf.newDocumentBuilder();
//解析文档
InputStream is = Thread.currentThread().getContextClassLoader().getResourceAsStream("com/booy/person.xml");
//将文档加载到内存中,以树状结构存储
Document doc = documentBuilder.parse(is);
//从内存中读取数据
NodeList personNodeList = doc