代码已上传到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区别

  1. Xml是重量级数据交换格式,占宽带比较大。
  2. JSON是轻量级交换格式,xml占宽带小。
  3. 所有很多互联网公司都会使用json作为数据交换格式
  4. 很多银行项目,大多数还是在使用xml。

2. SpringIOC

SpringIOC 指的是控制反转,IOC容器负责实例化、定位、配置应用程序中的对象及建立这些对象间的依赖,交由Spring来管理这些,实现解耦。

原理:使用反射机制+XML技术

待补充…

总结

源码分析系列教程(03) - Spring核心总结(IOC篇)_# 源码分析