XML语法
XML文档声明
<?xml version="1.0" encoding="UTF-8"?>1.文档声明必须为<?xml开头,以?>结束;
2.文档声明必须从文档的0行0列位置开始;
3.文档声明只有三个属性:
a)versioin:指定XML文档版本。必须属性,因为我们不会选择
1.1,只会选择1.0;
b)encoding:指定当前文档的编码。可选属性,默认值是utf-8;
c)standalone:指定文档独立性。可选属性,默认值为yes,表示当
前文档是独立文档。如果为no表示当前文档不是独立的文档,会
依赖外部文件。
元素
<servlet>
1.元素是XML文档中最重要的组成部分,
2.普通元素的结构由开始标签、元素体、结束标签组成。例如:大家好
3.元素体:元素体可以是元素,也可以是文本,例如:你好
4.空元素:空元素只有开始标签,而没有结束标签,但元素必须自己闭合,例如:
5.元素命名:
a)区分大小写
b)不能使用空格,不能使用冒号:
c)不建议以XML、xml、Xml开头
6.良好的XML文档,必须有一个根元素。
属性
<web-app version="2.5">
1.属性是元素的一部分,它必须出现在元素的开始标签中
2.属性的定义格式:属性名=属性值,其中属性值必须使用单引或双引
3.一个元素可以有0~N个属性,但一个元素中不能出现同名属性
4.属性名不能使用空格、冒号等特殊字符,且必须以字母开头
注释
XML的注释与HTML相同,即以<!- -, 以–>"结束。注释内容会被XML解析器忽略!
转义字符
XML中的转义字符与HTML一样。
因为很多符号已经被XML文档结构所使用,所以在元素体或属性值中想使用这些符号就必须使用转义字符,例如:“<”、“>”、“’”、“””、“&”。
例子:
配置文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5">
<servlet>
<servlet-name>HelloMyServlet</servlet-name>
<servlet-class>cn.itcast.HelloMyServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>HelloMyServlet</servlet-name>
<url-pattern>/hello</url-pattern>
</servlet-mapping>
</web-app>
存放数据
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="p001">
<name>张三</name>
</person>
<person id="p002">
<name>李四</name>
</person>
</persons>`
在XML中添加DTD约束的几种情况
1.内部DTD,在XML文档内部嵌入DTD,只对当前XML有效。
<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
<!DOCTYPE web-app [
... //具体的语法
]>
<web-app>
</web-app>
2.外部DTD—本地DTD,DTD文档在本地系统上,公司内部自己项目使用。
<?xml version="1.0" encoding="utf-8" standalone="no" ?>
<!DOCTYPE web-app SYSTEM "web-app_2_3.dtd">
<web-app>
</web-app>
3.外部DTD—公共DTD,DTD文档在网络上,一般都有框架提供。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
</web-app>
在XML中添加Schema约束
注意:xmlns=“http://www.example.org/web-app_2_5”
xmlns:xsi=“http://www.w3.org/2001/XMLSchema-instance”
xsi:schemaLocation="http://www.example.org/web-app_2_5 web-app_2_5.xsd"称之为命名空间,在实际开发中可以从框架中提供的帮助文档中获得。
命名空间的定义:如果一个XML文档中使用多个Schema文件,而这些Schema文件中定义了相同名称的元素时就会出现名字冲突。这就像一个Java文件中使用了import java.util.*和import java.sql.*时,在使用Date类时,那么就不明确Date是哪个包下的Date了。
总之名称空间就是用来处理元素和属性的名称冲突问题,与Java中的包是同一用途。如果每个元素和属性都有自己的名称空间,那么就不会出现名字冲突问题,就像是每个类都有自己所在的包一样,那么类名就不会出现冲突。
声明命名空间
默认命名空间:<xxx xmlns=””>
,使用<标签>
显式命名空间:<xxx xmlns:别名=””>
, 使用<别名:标签>
实例:web-app_2_5.xsd
<xsd:schema xmlns:xsd=“http://www.w3.org/2001/XMLSchema” …>
表示自定义schema约束文档引用官方文档作为显示命名空间。如果要使用官方提供的元素或属性,必须使用xsd前缀(自定义,此处表示官方文档,所以使用xsd)
xsd:schema标签就有官方文档提供,默认命名空间直接使用。
实例:web.xml
<web-app xmlns=http://www.example.org/web-app_2_5 …>
表示 xml 文档引用“自定义约束文档”作为默认命名空间因为使用默认命名空间,直接使用
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://www.example.org/web-app_2_5"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.example.org/web-app_2_5 web-app_2_5.xsd"
version="2.5">
<servlet>
<servlet-name></servlet-name>
<servlet-class></servlet-class>
</servlet>
<servlet-mapping>
<servlet-name></servlet-name>
<url-pattern></url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file></welcome-file>
<welcome-file></welcome-file>
<welcome-file></welcome-file>
</welcome-file-list>
</web-app>
servlet配置文件中的标签
<!ELEMENT web-app (servlet*,servlet-mapping* , welcome-file-list?) >web-app 包括3个标签,且必须顺序出现。
servlet子标签个数任意
servlet-mapping 子标签个数任意
welcome-file-list 子标签最多只能出现一次
<!ELEMENT servlet (servlet-name,description?,(servlet-class|jsp-file))>
servlet 有3个子标签,且必须顺序出现
servlet-name,必须有,且只能出现一次
description,可选一次
servlet-class 和 jsp-file 二选一,且只能出现一次
<!ELEMENT servlet-name (#PCDATA)>
servlet-name 的标签体必须是文本
<!ELEMENT welcome-file-list (welcome-file+)>
welcome-file-list 至少有一个子标签welcome-file