概念
XML(EXtensible Markup Language),可扩展标记语言。可扩展就是<>内的东西可以自己定义,可以随便写。标记语言就是加了<>符号的 。HTML是超文本标记语言,不可以拓展,因为你写个<p> 浏览器知道这个是段落,你写个<shuyunquan>浏览器就不认识了,所以不可拓展。
XML书写格式
- 第一行是固定的:<?xml version="1.0" encoding="UTF-8"?>,告诉别人,我是xml文件。
- 只能有一个根元素
- 没了
其他语法和注意点
- <!--这是注释 -->
- <元素名 属性名="属性值">元素内容</元素名>,元素也称标签,XML文件是由一系列标签构成的。属性值不要使用乱七八糟的符号,如>\/<等
- 所有XML元素都必须有结束标签(</……>)
- XML标签对大小写敏感
- XML必须正确的嵌套
- 同级标签以缩进对齐
- 元素名称可以包含字母、数字或其他的字符
- 元素名称不能以数字或者标点符号开始(<5name>是错误的;<name5>是正确的)
- 元素名称中不能含空格(<student name>是错误的;<studentname>是正确的的)
DOM解析XML
- 文档对象模型(Document Object Model)
- DOM把XML文档映射成一个倒挂的树
<book id=”1234”>
<title>三国演义</title>
<author>罗贯中</author>
<price>30元</price>
</book>
知识兔所有带尖括号的叫元素节点,只有文本文字的叫属性节点,id=”1234”叫做属性节点
树形结构:易于增删改查
DOM解析XML文件步骤:
- 创建解析器工厂对象
- 解析器工厂对象创建解析器对象
- 解析器对象指定XML文件创建Document对象
- 以Document对象为起点操作DOM树
类似这种套路:
1 import javax.xml.parsers.*;
2 import org.w3c.dom.*;
3 import java.io.*;
4 import java.net.URL;
5
6 public class XMLUtil {
7
8 public static Object getBean() {
9 try {
10 //创建DOM文档对象
11 DocumentBuilderFactory dFactory=DocumentBuilderFactory.newInstance();//文档制造者工厂创建了一个 文档制造者工厂对象
12 DocumentBuilder builder=dFactory.newDocumentBuilder();//文档制造者类 通过 文档制造者工厂 创造一个 文档制造者对象
13 Document doc;//文档制造者 创建 文档
14 doc=builder.parse(new File("src/homework/config.xml"));//解析xml文件
15
16 //获取包含类名的文本节点
17 NodeList nl=doc.getElementsByTagName("className");//文本节点列表里有很多被className标签夹着的内容
18 Node classNode=nl.item(0).getFirstChild();
19 //item(0)表示引用列表里第一个节点,这里只有一个。getFirstChild表示获取该节点的第一个孩子。
20 String cName=classNode.getNodeValue();
21
22 //通过类名生成实例对象并返回
23 Class c=Class.forName(cName);
24 Object obj=c.newInstance();
25 return obj;
26 }catch(Exception e) {
27 e.printStackTrace();
28 return null;
29 }
30 }
31 }
知识兔套路参考:https://blog.csdn.net/baidu_29343517/article/details/81609732