XML
可扩展标记语言,XML的设计宗旨是传输和存储数据,HTML用来显示数据,焦点是数据的外观
web方面优点:
XML把数据从HTML分离
XML简化数据共享
XML简化数据传输
XML简化平台的变更
XML使数据更有用
XML文档组成:
1.XML声明
<? xml 版本信息 [编码信息] [文档独立性信息] ?>
<?xml version="1.0" encoding="gb2312" standalone="yes"?>
2.XML文档类型声明,两种形式
声明DTD在一个外部文件中,是以.dtd为扩展名的文本文件
<!DOCTYPE 根元素 SYSTEM"文件名">
<!DOCTYPE poem SYSTEM "c.dtd">
直接在XML文档中给出DTD,形式为
<!DOCTYPE 根元素 [元素声明]>
<!DOCTYPE poem [
<!ELEMENT poem (title, author, content)>
<!ELEMENT title (#PCDATA)>
xxxx
3.元素
4.XML注释
5.XML处理指令
<? target instruction?>
解析XML的三种方式
DOM:会将XML文件的所有内容以文档树的方式存放在内存中,允许用户使用DOMAPI遍历XML树,检索所需的数据
基本流程:
1.利用DocumentBuilderFactory创建一个DocumentBuilderFactory实例
2.利用DocumentBuilderFactory创建DocumentBuilder
3.加载XML文档(Document)
4.获取文档的根节点(Element)
5.获取根节点中所有子节点的 列表(NodeList)
6.获取子节点列表中的需要读取的节点
SAX解析XML
基于事件驱动,边加载边解析
基本流程:
1.创建SAXParseFactory对象
2.根据SAXParserFactory.newSAXParser()方法返回一个SAXParser解析器
3.根据SAXParser解析器获取事件源对象XMLReader
4.实例化一个DefaultHandler对象
5.连接事件源对象XMLReader到时间处理类DefaultHandler中(setContentHandler)
6.调用XMLReader的parse方法从输入源中获取的XML数据
7.通过DefaultHandler返回需要的数据集合
PULL解析XML
方式与SAX解析一样,基于事件驱动
XmlPullParserFactory factory;
//实例化XmlPullParserFactory
factory = XmlPullParserFactory.newInstance();
//设置支持名称空间
factory.setNamesapceAware(true);
//创建XmlPullParser类
XmlPullParser xpp = factory.newPullParser();
//将xml文本读入XmlPullParser解析器
xpp.setInput(new StringReader("<poem lang=\"chinese\"><title>静夜思</title><author>李白</author><content>床前明月光....</content></poem>"));
//定义pull解析常用事件类型
int eventType = xpp.getEventType();
//查看是否为XML文档的逻辑末尾,输入流的末尾
while(eventType != XmlPullParser.END_DOCUMENT) {
//查看是否为文档开始类型
if(eventType == XmlPullParser.START_DOCUMENT) {
Log.d(TAG,"start document");
}else if (eventTpe == XmlPullParser.START_TAG) {
//是否XML标签的开始
Log.d(TAG,"start tag" + xpp.getName());
} else if(eventType == XmlPullParser.END_TAG) {
//是否XML标签的结束
Log.d(TAG,"End tag" + xpp.getName());
} else if(eventType == XmlPullParser.TEXT) {
//是否XML的文本内容
Log.d(TAG,"Text " + xpp.getText());
}
//获取下个解析事件
eventType = xpp.next();