代码已上传到GitHub,有兴趣的同学可以下载来看看:https://github.com/ylw-github/Java-CodeAnalysis-Demo
1. XML技术
XML是可扩展标记语言(Extensible Markup Language,简称XML),是一种标记语言。
XML 全称为可扩展的标记语言,主要用于描述数据和用作配置文件。
XML 文档在逻辑上主要由一下 5 个部分组成:
- XML 声明:指明所用 XML 的版本、文档的编码、文档的独立性信息
- 文档类型声明:指出 XML 文档所用的 DTD
- 元素:由开始标签、元素内容和结束标签构成
- 注释:以结束,用于对文档中的内容起一个说明作用
- 处理指令:通过处理指令来通知其他应用程序来处理非 XML 格式的数据,格式为XML 文档的根元素被称为文档元素,它和在其外部出现的处理指令、注释等作为文档实体的子节点,根元素本身和其内部的子元素也是一棵树。
1.1 XML样例
<?xml version="1.0" encoding="UTF-8"?>
<students>
<student1 id="001">
<学号>20140101</学号>
<地址>北京海淀区</地址>
<座右铭>要么强大,要么听话</座右铭>
</student1>
<student2 id="002">
<学号>20140102</学号>
<地址>北京朝阳区</地址>
<座右铭>在哭泣中学会坚强</座右铭>
</student2>
</students>
<?xml version="1.0" encoding="UTF-8"?>
作用xml文件头部要写的话,说明了xml的版本和编码,utf-8一般是网络传输用的编码。
1.2 XML解析方式
有三种,百度谷歌了解:Dom4j、Sax、Pull
1.3 Dom4j与SAX
Dom4j :不适合大文件的解析,因为它是一下子将文件加载到内存中,所以有可能出现内存溢出。
SAX : 是基于事件来对xml进行解析的,所以他可以解析大文件的xml,也正是因为如此,所以dom4j可以对xml进行灵活的增删改查和导航,而sax没有这么强的灵活性,所以sax经常是用来解析大型xml文件,而要对xml文件进行一些灵活(crud)操作就用dom4j。
1.3.1 使用Dom4j解析xml
解析XML过程是通过获取Document对象,然后继续获取各个节点以及属性等操作,因此获取Document对象是第一步,大体说来,有三种方式:
方式一:其中students是根节点,可以继续添加其他节点等操作。
Document document = DocumentHelper.createDocument();
Element root = document.addElement("students");
方式二:
// 创建SAXReader对象
SAXReader reader = new SAXReader();
// 读取文件 转换成Document
Document document = reader.read(new File("XXXX.xml"));
方式三:读取XML文本内容获取Document对象
String xmlStr = "<students>......</students>";
Document document = DocumentHelper.parseText(xmlStr);
1.3.2 使用SAX解析xml
Xml配置:
<?xml version="1.0" encoding="UTF-8"?>
<students>
<student1 id="001">
<学号>20140101</学号>
<地址>北京海淀区</地址>
<座右铭>要么强大,要么听话</座右铭>
</student1>
<student2 id="002">
<学号>20140102</学号>
<地址>北京朝阳区</地址>
<座右铭>在哭泣中学会坚强</座右铭>
</student2>
</students>
Java代码:
public static void main(String[] args) throws SAXException, DocumentException {
XmlUtils xmlUtils = new XmlUtils();
xmlUtils.test001();
}
public void test001() throws DocumentException {
SAXReader saxReader = new SAXReader();
Document read = saxReader.read(getClassPath("student.xml"));
// 获取根节点
Element rootElement = read.getRootElement();
getNodes(rootElement);
}
public InputStream getClassPath(String xmlPath) {
InputStream resourceAsStream = getClass().getClassLoader().getResourceAsStream(xmlPath);
return resourceAsStream;
}
public static void getNodes(Element rootElement) {
System.out.println("获取当前名称:" + rootElement.getName());
// 获取属性信息
List<Attribute> attributes = rootElement.attributes();
for (Attribute attribute : attributes) {
System.out.println("属性:" + attribute.getName() + "---" + attribute.getText());
}
// 获取属性value
String value = rootElement.getTextTrim();
if (!StringUtils.isEmpty(value)) {
System.out.println("value:" + value);
}
// 使用迭代器遍历,继续遍历子节点
Iterator<Element> elementIterator = rootElement.elementIterator();
while (elementIterator.hasNext()) {
Element next = elementIterator.next();
getNodes(next);
}
注意:this.getClass().getClassLoader().getResourceAsStream(xmlPath) 获取当前项目路径xmlfsfs。
1.4 XML与JSON区别
- Xml是重量级数据交换格式,占宽带比较大。
- JSON是轻量级交换格式,xml占宽带小。
- 所有很多互联网公司都会使用json作为数据交换格式
- 很多银行项目,大多数还是在使用xml。
2. SpringIOC
SpringIOC 指的是控制反转,IOC容器负责实例化、定位、配置应用程序中的对象及建立这些对象间的依赖,交由Spring来管理这些,实现解耦。
原理:使用反射机制+XML技术
待补充…