代码已上传到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技术
待补充…
总结