一、理论准备
二、上代码
<?xml version="1.0" encoding="utf-8" ?><persons><person id="23"><name>Jack</name><age>21</age></person><person id="20"><name>Dick</name><age>23</age></person></persons>
package cn.bgxt.service;import java.io.InputStream;import java.util.ArrayList;import java.util.List;import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory;import javax.xml.parsers.ParserConfigurationException;import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.Node;import org.w3c.dom.NodeList;import cn.bgxt.domain.Person;public class DomService {public DomService() {// TODO Auto-generated constructor stub}public static List<Person> getPersons(InputStream inputStream) throws Exception{List<Person> list=new ArrayList<Person>();//获取工厂对象,以及通过DOM工厂对象获取DOMBuilder对象DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();DocumentBuilder builder=factory.newDocumentBuilder();//解析XML输入流,得到Document对象,表示一个XML文档Document document=builder.parse(inputStream);//获得文档中的次以及节点,personsElement element=document.getDocumentElement();// 获取Element下一级的person节点集合,以NodeList的形式存放。NodeList personNodes=element.getElementsByTagName("person");for(int i=0;i<personNodes.getLength();i++){//循环获取索引为i的person节点Element personElement=(Element) personNodes.item(i);Person person=new Person();//通过属性名,获取节点的属性idperson.setId(Integer.parseInt(personElement.getAttribute("id")));//获取索引i的person节点下的子节点集合NodeList childNodes=personElement.getChildNodes();for(int j=0;j<childNodes.getLength();j++){//循环遍历每个person下的子节点,如果判断节点类型是ELEMENT_NODE,就可以依据节点名称给予解析if(childNodes.item(j).getNodeType()==Node.ELEMENT_NODE){if("name".equals(childNodes.item(j).getNodeName())){//因为文本也是一个文本节点,//所以这里读取到name节点的时候,//通过getFirstChild()可以直接获得name节点的下的第一个节点,就是name节点后的文本节点//取其value值,就是文本的内容person.setName(childNodes.item(j).getFirstChild().getNodeValue());}else if("age".equals(childNodes.item(j).getNodeName())){person.setAge(Integer.parseInt(childNodes.item(j).getFirstChild().getNodeValue()));}}}//把解析的person对象加入的list集合中list.add(person);}return list;}}
三、遗留问题
解析xml必须事先知道xml的结构么?不知道不行么?
四、参考文献
