第一章 XML
1 XML概述
目标
- 什么是XML
什么是XML
- 英文:eXtensible Markup Language 可扩展的标记语言,由各种标记(标签,元素)组成。
- 可扩展:所有的标签都是自定义的,可以随意扩展的。如:<abc/>,<姓名>
- 标记语言:整个文档由各种标签组成。清晰,数据结构化!
- XML是通用格式标准,全球所有的技术人员都知道这个东西,都会按照XML的规范存储数据,交互数据!!
XML作用
作用:总体上来说,就是为了存储维护数据的。
-
数据交换:不同的计算机语言之间,不同的操作系统之间,不同的数据库之间,进行数据交换。
-
配置文件:在后期我们主要用于各种框架的配置文件基本天天见。
比如 连接池:c3p0-config.xml 日志:logback.xml
小结
- xml是什么?
- 可扩展的标记语言
- 标记:标签。例:
- xml文件是由N多个标签组成的
- 可扩展的标记语言
- 主要有哪两个作用?
- 存储数据
- 配置文件(主流)
2 编写第1个XML文件
需求
编写xml文档,用于描述人员信息,person代表一个人员,id是人员的属性代表人员编号。人员信息包括age年龄、name姓名、sex性别信息。
使用Java类去描述:
class Person{
String id;
int age;
String name;
String sex;
}
Person p = new Person("1","张三",18,"男");
效果
步骤
-
选择当前项目鼠标右键新建
新建一个File命名时,以 .xml结尾。这个文件就是xml文件
-
编写person.xml文件
<?xml version="1.0" encoding="UTF-8" ?> <peopel> <person> <id>1</id> <name>张三</name> <age>18</age> <sex>男</sex> </person> <person> <id>2</id> <name>李四</name> <age>20</age> <sex>女</sex> </person> </peopel>
-
通过浏览器解析XML的内容
- 注:XML以后通过Java来进行解析,很少直接在浏览器上显示。
小结:
- xml文件,通常以.xml作为后缀名
- xml文件中的首行必须书写: <?xml version="1.0" encoding="UTF-8" ?> (固定写法)
- xml文件通常是由成对标签(开始标签、结束标签)组成
3 XML的组成:声明和元素
目标
- XML文档中的声明
- XML文档中的元素
XML组成
- 声明
- 元素(标签)
- 属性
- 注释
- 转义字符【实体字符】
- CDATA 字符区
文档声明
<?xml version="1.0" encoding="utf-8" ?> 固定格式
-
IDEA会自动提示。
-
文档声明必须为<?xml开头,以?>结束
-
文档声明必须从文档的1行1列位置开始,必须在xml文档中的首行首列
-
文档声明中常见的两个属性:
- version:指定XML文档版本。必须属性,这里一般选择1.0;
- encoding:指定当前文档的编码,可选属性,默认值是utf-8;
元素(标签、标记)
格式1: <person> 标签体 </person> 有标签体的标签 (双标签)
格式2: <person/> 没有标签体的标签 (空标签) (单标签)
-
元素是XML文档中最重要的组成部分;
-
普通元素的结构由开始标签、元素体、结束标签组成。【格式1】
-
元素体:元素体可以是元素,也可以是文本,例如:
<person> 标签中可以包含另一个标签 <name>张三</name> </person>
-
空元素:空元素只有标签,而没有结束标签,但元素必须自己闭合,例如:
<sex/>
-
元素命名
- 区分大小写
- 不能使用空格,不能使用冒号
- 不建议以XML、xml、Xml开头
- 标签名不能数字开头,可以有数字
- 可以使用下划线
可以保持与Java命名标识符一样的规则
-
格式化良好的XML文档,有且仅有一个根元素。
错误演示:
元素没有结束
元素大写小写不一致
xml中多个根
小结
-
声明有哪两个常用的属性?
- version
- encoding
-
一个XML有几个根元素?
- 有且只能有一个根元素
-
XML标签命名不能有什么符号?
- 不能使用关键字xml、XML
- 不能有空格、不能有冒号
- 不能以数字作为开头
4 XML的组成:属性、注释和转义字符
属性的语法
<person id="110" id2="11">
-
属性是元素的一部分,它必须出现在元素的开始标签中
-
属性的定义格式:
属性名=“属性值”
,其中属性值必须使用单引或双引号括起来 -
一个元素可以有0~N个属性,但一个元素中不能出现同名属性
-
属性名不能使用空格 , 建议不要使用冒号等特殊字符,且必须以字母开头
建议以Java的标识符定义规则做参考
<person id="123">
<name>张三</name>
</person>
注释
<!-- 注释内容 -->
<!--
注释内容 1
注释内容 2
-->
XML的注释与HTML相同,既以<!--
开始,-->
结束。不能嵌套。
Java中注释:
// 单行
/* */ 多行注释
/** */ 文档注释
XML注释:
<!-- 注释内容 -->
<!--<person>注释</person>--> <!-- 快捷键:Ctrl+/ :可以将整行进行注释-->
<person>三生三世</person> <!-- 快捷键:Ctrl+Shift+/:局部注释-->
转义字符[实体字符]
XML中的实体字符与HTML一样。因为很多符号已经被文档结构所使用,所以在元素体或属性值中想使用这些符号就必须使用实体字符
字符 | 预定义的转义字符 | 说明 |
---|---|---|
< | < | 小于(less than) |
> | > | 大于(greater than) |
" | " | 双引号(quotation) |
’ | ' | 单引号(apostrophe) |
& | & | 和号(ampersand ) |
注意:严格地讲,在 XML 中仅有字符 “<“和”&” 是非法的。省略号、引号和大于号是合法的,但是把它们替换为实体引用是个好的习惯。
转义字符应用示例:
假如您在 XML 文档中放置了一个类似 “<” 字符,那么这个文档会产生一个错误,这是因为解析器会把它解释为新元素的开始。因此你不能这样写:
<message>if salary < 1000 then </message>
为了避免此类错误,需要把字符 “<” 替换为实体引用,就像这样:
<message>if salary < 1000 then</message>
小结
-
属性必须出现在标签哪个位置?
-
和开始标签绑定在一起,书写在开始标签元素的后面
-
<person id="属性值"> </person>
-
-
同一个标签是否可以有同名的属性?
- 不可能。
- 允许有多个属性,属性之间使用空格分隔,但不能出现相同名称的属性
-
为什么要有转义字符(实体字符)?
- 在xml文件中,一些特定的符号已经被xml使用了。例:> & 等
- 希望在xml文档中,使用特定的符号,需要用:转义字符
- < =>
<
- & =>
&
- < =>
-
注释的快捷?
- ctrl + /
5 XML的组成:字符区(了解)
当大量的转义字符出现在xml文档中时,会使XML文档的可读性大幅度降低。这时如果使用CDATA段就会好一些。
CDATA (Character Data)字符数据区,格式如下:
<![CDATA[
文本数据 < > & ; " "
]]>
- CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)
- CDATA 部分由
<![CDATA[
开始,由]]>
结束;
例如:
<![CDATA[
if salary < 1000 then
]]
快捷模板:CD 回车
注意:
CDATA 部分不能包含字符串 “]]>”。也不允许嵌套的 CDATA 部分。
标记 CDATA 部分结尾的 “]]>” 不能包含空格或折行。
小结:
- 字符区的特点:
- 原样显示(书写的内容不会被xml解析器解析)
6 XML约束:DTD约束
目标
- XML有哪两种约束
- 了解DTD约束
1. XML约束
在XML技术里,可以编写一个文档来约束一个XML文档的书写规范,这称之为XML约束。
常见的xml约束:DTD、Schema
注意:我们对于约束的要求是能通过已写好的约束文件编写xml文档.
2. 约束体验
体验效果说明:当编写xml文档时不符合指定dtd约束时,进行提示xml编写错误,如下图:
体验步骤:
步骤1:复制bookshelf.dtd文件
步骤2:bookshelf.dtd文件内容如下
<!ELEMENT 书架 (书+)> <!-- 声明了根元素,并指定了根元素下必须有的一个子元素 -->
<!-- 声明子元素 书 -->
<!ELEMENT 书 (书名,作者,售价)><!--约束元素书的子元素必须为书名、作者、售价-->
<!-- , 表示必须按照元素的顺序出现 -->
<!ELEMENT 书名 (#PCDATA)> <!-- #PCDATA : 表示文本内容 -->
<!ELEMENT 作者 (#PCDATA)>
<!ELEMENT 售价 (#PCDATA)>
步骤三:新建books.xml,代码如下
引用 <!DOCTYPE 根元素 SYSTEM "dtd约束文件的路径">
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE 书架 SYSTEM "bookshelf.dtd"><!--指定使用bookshelf.dtd文件约束当前xml文档-->
<书架>
<书>
<书名>JavaWeb开发教程</书名>
<作者>张孝祥</作者>
<售价>100.00元</售价>
</书>
<书>
<书名>三国演义</书名>
<作者>罗贯中</作者>
<售价>100.00元</售价>
<测试>hello</测试><!--不符合约束,书的子元素必须为书名、作者、售价-->
</书>
</书架>
步骤四:idea开发工具books.xml的dtd约束验证不通过的效果如下
3. DTD学习要求
在企业实际开发中,我们很少自己编写DTD约束文档,通常情况下通过框架提供的DTD约束文档编写对应的XML文档。所以这一知识点的要求是可以根据DTD约束文档内容编写XML文档。
小结:
在xml文件中引入DTD约束文件
<!DOCTYPE 根元素 SYSTEM "约束文件的路径">
7 XML约束:Schema约束
目标
了解Schema约束
1 概念
Schema 语言也也叫做 XSD(XML Schema Definition)。
其本身也是XML格式文档,但Schema文档扩展名为xsd,而不是xml。
Schema 功能更强大,数据类型约束更完善。 比DTD强大,是DTD代替者。
2 约束体验
体验效果说明:体验schema约束XML文档中对元素体数据类型的约束。
效果如下:
DTD约束无法对具体数据类型进行约束,所以开发工具没有任何错误提示,如下效果:
实现步骤
步骤1:复制schema约束文件bookshelf.xsd,其中已对售价约束了数据类型,代码如下
<?xml version="1.0" encoding="UTF-8" ?>
<!--
传智播客schema教学实例文档.将注释中的以下内容复制到要编写的xml的声明下面
复制内容如下:
<书架 xmlns="http://www.itcast.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.itcast.cn bookshelf.xsd"
>
-->
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.itcast.cn"
elementFormDefault="qualified">
<xs:element name='书架' >
<!-- complexType : 复杂元素
xml文档中的某个标签,有子标签或有属性,该标签就为:复杂元素
例: <书架> <书>
简单元素:
没有子标签、没有属性。 例:书名、作者、售价
-->
<xs:complexType>
<xs:sequence maxOccurs='unbounded' >
<xs:element name='书' >
<xs:complexType>
<xs:sequence>
<xs:element name='书名' type='xs:string' />
<xs:element name='作者' type='xs:string' />
<xs:element name='售价' type='xs:double' />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
步骤2:新建books2.xml使用schema约束文件bookshelf.xsd,代码如下
<?xml version="1.0" encoding="UTF-8"?>
<书架
xmlns="http://www.itcast.cn"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.itcast.cn bookshelf.xsd"
><!--指定schema文档约束当前XML文档-->
<书>
<书名>JavaScript网页开发</书名>
<作者>张孝祥</作者>
<售价>abc</售价>
</书>
</书架>
步骤3:开发工具提示效果
3 名称空间
一个XML文档最多可以使用一个DTD文件,但一个XML文档中使用多个Schema文件,若这些Schema文件中定义了相同名称的元素时,使用的时候就会出现名字冲突。这就像一个Java文件中使用了import java.util.*
和import java.sql.*
时,在使用Date类时,那么就不明确Date是哪个包下的Date了。
同理 , 在XML文档中就需要通过名称空间(namespace)来区分元素和属性是来源于哪个约束中的。
名称空间就在在根元素后面的内容 , 使用xmlns到引入约束 。
当一个XML文档中需要使用多个Schema文件的时候 , 有且仅有一个使用缺省的 , 其他的名称空间都需要起别名 。
参考资料中的 applicationContext.xml文件(spring框架的配置文件)
xmlns="http://www.itcast.cn"
<!-- 缺省的名称空间.使用此约束中的元素的时候只需要写元素名即可 例如:<书></书> -->
xmlns:aa="http://java.sun.com"
<!-- aa就是此约束的别名,使用此约束中的元素的时候就需要加上别名 例如:<aa:书></aa:书> -->
总之名称空间就是用来处理元素和属性的名称冲突问题,与Java中的包是同一用途。如果每个元素和属性都有自己的名称空间,那么就不会出现名字冲突问题,就像是每个类都有自己所在的包一样,那么类名就不会出现冲突。
4 schema学习要求
虽然schema功能比dtd强大,但是编写要比DTD复杂,同样以后我们在企业开发中也很少会自己编写schema文件。
xml编写与约束内容已经完成了,根据xml的作用我们了解到,无论是xml作为配置文件还是数据传输,我们的程序都要获取xml文档中的数据以便我们进行具体的业务操作,接下来我们就要学习XML解析技术Dom4j。
小结:
怎么引入xsd 文档
<?xml version="1.0" encoding="UTF-8" ?>
<根元素 xmlns="命名空间"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="命名空间 文件路径"
>
</根元素>
schemaLocation:指定命名空间所在的文件
命名空间在约束文件的:targetNamespace中