W3C制定了一套XML分析器的标准接口规范---DOM,除此之外,其他机构也制定了一套接口规范---SAX.
xml文档--->xml分析器--->接口(DOM或者SAX)--->XML应用程序.
DOM 由三部分组成:核心(core),html和xml.
核心部分是结构化文档比较底层对象的集合,这一部分所定义的对象已经完全可以表达出任何
HTML和XML文档中的数据.
在DOM接口规范中,有四个基本的接口:Document,Node,NodeList,NamedNodeMap.
document接口是对文档进行操作的入口,它是从node接口继承过来的.
node接口是其他大多数接口的父类.
nodeList接口是一个节点的集合,包含了某个节点的所有子节点.
namedNodeMap接口也是一个节点的集合,通过该接口,可以建立节点名和节点之间一一映射关系.
------------------------------------***感谢风中叶老师视频指导***---------------------------------------------
利用DOM将xml文件打印出来的代码.
public class ViewXml {
static String xmlStr = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n";
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document document = db.parse("src/DOM/one.xml");
Element de = document.getDocumentElement();
doXml(de);
System.out.println(xmlStr);
}
private static void doXml(Element de){
xmlStr = xmlStr + "<" + de.getNodeName();
if(de.hasAttributes()){
NamedNodeMap nnm = de.getAttributes();
for(int i=0;i<nnm.getLength();i++){
Node node = nnm.item(i);
xmlStr = xmlStr + " " + node.getNodeName() + "=\"" + node.getNodeValue() + "\"";
}
}
xmlStr = xmlStr + ">";
NodeList nlist = de.getChildNodes();
for(int i=0;i<nlist.getLength();i++){
Node node = nlist.item(i);
if(node.getNodeType() == Node.ELEMENT_NODE){
doXml((Element)node);
}else if(node.getNodeType() == Node.TEXT_NODE){
xmlStr = xmlStr + node.getNodeValue();
}
}
xmlStr = xmlStr + "</" + de.getNodeName() + ">";
}
}