XML学习

XML学习(1)

1.什么是xml

Extensive Markup Language,可扩展标记语言。

1)xml是一种语言,和java语言一样,也有自己的语法规则。

2)标记语言,和html相同,是一种标记语言。构成xml代码的内容基本都是“标记”

3)可扩展
所使用到的所有的标记标签(简称标签),全部都可以自己定义。
标签名以及标签中所有的属性名都可以自己任意定义。
灵活度比较高。
xml的本质就是一种特殊的文本信息。

2.xml有什么作用

1)xml是一种数据持久化技术
数据持久化:数据是保存在磁盘中,而不是保存内存中的。

  a)使用文本文件保存信息,例如.txt文件 
     弊端:保存数据的格式不规范,导致了解析数据的难度加大。
  b)xml
     特点:保存的数据具有结构性,使用程序读取和解析数据的时候非常容易。
           xml不需要依赖于任何的软件和环境。
           在任何一个操作系统中都可以直接创建、编辑、查看
  c)数据库软件
     适合用来处理重量级的数据,使用成本比较高。
     需要下载、安装、配置、部署、学习.....

2)用作轻量级数据的传输和保存

3)常用于项目中的配置文件,用来保存少量的配置信息

3.xml中的基本概念

1)标签 Tag
标记标签。xml文档的主要组成部分。
语法: <标签名>…</标签名>
标签必须是成对出现的:包含一个开始标签,包含一个结束标签
开始标签:<标签名>
结束标签:</标签名>
开始标签和结束标签标签名必须相同。
开始标签和结束标签范围之间的部分叫做标签体,可以包含一些内容。

2)元素 Element
元素和标签是有一定关联的。
标签:只强调开始标签和结束标签以及属性,并不重视标签体中包含什么信息
元素:代表从开始标签开始、到结束标签之间所包含的所有内容,称之为一个元素。

3)属性 Attribute
对标签/元素进行额外的附加说明。
属性声明在标签的头部(开始标签)。
以键值对的形式存在。
属性值必须要加双引号。
可有有多组属性,每组属性之间使用空格分隔

<student id="1001" age="22" teacher="2001,tom,22,male">
		<name>tom</name>
		<gender>male</gender>
		<teacher>
			<id>2001</id>
			<name>tom</name>
			<age>22</age>
			<gender>male</gender>
		</teacher>
</student>

4)注释

<!--    注释内容    --> 
<!--    
	注释内容
	注释内容
	注释内容
--> 

4.如何编辑一个xml文档

任何文本编辑器都可以编写xml文档。
记事本、editplus、notepad++、sublime.......
除此之外,主流的IDE工具都自带了XML的编辑器,并且非常强大。
例如,Eclipse、MyEclipse、IDEA

5.如何编写一个结构良好/格式良好的XML文档

1)必须拥有头部声明
<?xml version="1.0" encoding="UTF-8" ?>

2)必须有且只有一个根元素
根元素:直接定义在xml源文件中的元素,没有被其他元素包含。
直接定义在文档中的元素只能有一个,其他所有的元素必须直接或间接包含在这个根元素中。

3)标签名和属性名是大小写敏感的
区分大小写

<hello> </HELLO>

4)标签必须成对出现
在xml中所有的标签必须都有结束标签
在html中有部分标签可以没有结束标签

5)标签必须正确嵌套:一个标签如果要包含另外一个标签的话,必须要同时包含它的开始标签和结束标签。

<student>
  <teacher>
</student>
  </teacher>  <!--错误嵌套-->

6.如何编写一个有效的XML文档

两点要求:
1)必须是一个结构良好的XML文档
2)必须使用DTD或者XSD约束文档语义

7.DTD文档约束

xml本身存在很高的灵活度,所以导致每个程序编写的xml文件差异较大,导致标准不能得到统
一,解析的时候难度较大。需要使用DTD对文档内容进行约束。
约束:制定规则,哪些内容可以出现,哪些内容不能出现,需要让一个xml添加dtd约束,有两种实现方式:

1)内部式

  内部:被约束的xml文件的内部 
            DTD代码全部定义在xml文件中
  语法:<!DOCTYPE 根元素 [元素声明]>
  元素声明:允许出现哪些元素、不允许出现哪些元素、元素必须按照什么顺序排列、
           每种元素能够出现多少次、元素中必须拥有哪些属性、属性是什么类型、
	       有无默认值、是否必要......
    a)ELEMENT用来定义元素的
      语法:
	   <!ELEMENT 元素名称 类型>
	   <!ELEMENT 元素名称 内容>
	   <!ELEMENT note (to,from,heading,body)>
	    在node元素中只能出现to、from、heading、body子元素
	   【注意】这样的写法还同时定义数量和序列(顺序)
	    数量词:用于定义某个元素可以出现多次 
	    加在元素名称后边,代表该元素可以出现多少次
	    + 可以出现一次或多次,至少出现一次
	    ? 可以出现零次或一次。
	    * 可以出现零次或多次,任意次数。
	    #PCDATA:元素内容必须是解析器会解析的文本字符串信息
		         约束元素不能有子元素,只能包含纯文本
	             <!ELEMENT 元素名称 EMPTY>
	             元素必须是空元素。
	    空元素:开始标签和结束标签之间没有任何内容
               <hello></hello>
        <!ELEMENT 元素名称 ANY>
        元素中包含的可以使任意内容。
    b)ATTLIST用来定义属性
       <!ATTLIST 元素名 属性名 属性类型 默认值>
       <!ATTLIST to name CDATA "1001">

2)外部式
把DTD单独定义在一个独立的.dtd文件中。
在xml文件中通过简要的声明将这个外置的DTD文件引入进来。

8.使用JavachengxujiexiXML文档

1)SAX:基于事件驱动式的、类似爬虫式的解析

2)DOM:给予树形文档结构的解析方式,在开始读取一个文档之前,把整个文档全部都加载到内存中,变成一颗树形结构。

上述两种方式都是JDK中原生的解析方式

3)Dom4j------Dom for java
第三方的----使用之前需要先下载Dom4j.jar文件

开源、免费
Document Object Model—文档对象模型
可以实现对xml文档的增删改查
jar包的使用:
在普通JavaSE工程当中,jar包的使用分为两步:
1)先把jar文件拷贝到工程目录当中,放到工程下面任何位置都可以。
2)把这个jar文件添加到类加载路径中
jar文件右击—>Build Path—>Add to Build Path

感谢支持!!!!!!!!!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值