1.了解XML
1.1 什么是XML
XML 指可扩展标记语言(EXtensible Markup Language)。
XML 是一种很像HTML的标记语言。
XML 的设计宗旨是传输数据,而不是显示数据。
XML 标签没有被预定义。您需要自行定义标签。
XML 被设计为具有自我描述性。
XML 是 W3C 的推荐标准
1.2 XML与HTML的区别
XML 不是 HTML 的替代。
XML 和 HTML 为不同的目的而设计:
XML 被设计用来传输和存储数据,其焦点是数据的内容。
HTML 被设计用来显示数据,其焦点是数据的外观。
HTML 旨在显示信息,而 XML 旨在传输信息。
1.3 XML声明
<?xml version="1.0" encoding="utf-8"?>
version版本号
encoding 字符集编码
1.4 XLM的作用
xml的主要作用有:
1、用来保存数据,而且这些数据具有自我描述性
2、它还可以作为项目或者模块的配置文件
3、还可以用来做网络传输数据的格式(现在用不多了,都是JSON为主)
1.4 标准的XML格式
1)必须有xml的声明,例如<?xml version=”1.0”?>。
2)必须有且只有一个根元素。
3)标记大小写敏感。
4)属性值用引号,单引号双引号都可以,但必须一致。
4)标记成对出现。
5)空标记必须关闭,可以自关闭。例如:<book/>。
6)元素正确嵌套,不可以交叉重叠。
7)名称中可以包含字母数字或其他字符。
8)名称不能以数字开头。
9)名称中不能含有空格。
10)名称中不能包含冒号:(冒号被保留,用作命名空间使用)
2.元素的定义
要在web.xml文件中做限制有以下步骤
第一步:在XML加入DTD声明
语法:
<!DOCTYPE persons [里面放约束语句]>
第二步:加入约束语句同时加上属性定义
元素的分类:
<!ELEMENT element-name EMPTY>
<!ELEMENT element-name (#PCDATA)>
<!ELEMENT element-name (e1,e2)>
属性类型Type
与(,) 非(|)
次数:
0或1:?
0~N:*
1~N:+
属性描述
#REQUIRED:必填
#IMPLIED:非必填
默认值:只有type为(男|女)类型时,desc才可以用默认值的方式
案例
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE persons [
<!ELEMENT persons (person+)>
<!ELEMENT person (name,age,contact,br?)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT age (#PCDATA)>
<!ELEMENT contact (phone|email)>
<!ELEMENT phone (#PCDATA)>
<!ELEMENT email (#PCDATA)>
<!ELEMENT br EMPTY>
]>
<!--
建立xml约束:首先得分析xml结构
1.根标签persons
2.persons有子标签 混合标签(有子标签)
3.person有子标签:name、age、contact、br 混合标签(有子标签)
4.name、age没有子标签,有内容 文本标签
5.contact有子标签 混合标签(有子标签)
6.phone没有子标签,有内容 文本标签
7.br既没有子标签也没有文本内容 空标签
8.email没有子标签,有内容 文本标签
<!-- 属性约束(依赖)
attribute
属性约束分类
pid代表唯一 ID
sex代表 选择
qq代表 文本
parent IDREF reference
-->
<!ATTLIST person
pid ID #REQUIRED
sex (男|女) '男'
qq CDATA #IMPLIED
parent IDREF #IMPLIED
>
-->
<persons>
<person pid="p1" sex="男" qq="aaa" parent="p2">
<name>张小明</name>
<age>10</age>
<contact>
<phone>1234567</phone>
</contact>
<br/>
</person>
<person pid="p2">
<name>张大明</name>
<age>35</age>
<contact>
<email>123@qq.com</email>
</contact>
</person>
</persons>
扩展案例一:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE config [
<!ELEMENT config (action+)>
<!ELEMENT action (forward+)>
<!ATTLIST action
path CDATA '/'
type CDATA #IMPLIED
>
]>
<!--
config标签:可以包含0~N个action标签
-->
<config>
<!--
action标签:可以饱含0~N个forward标签 path:以/开头的字符串,并且值必须唯一 非空 ,子控制器对应的路径
type:字符串,非空,子控制器的完整类名
-->
<action path="/registerAction" type="test.action.RegisterAction">
<forward name="success" path="/index.jsp" redirect="true" />
<forward name="failed" path="/register.jsp" redirect="false" />
</action>
<action path="/loginAction" type="test.action.LoginAction">
<forward name="a" path="/index.jsp" redirect="false" />
<forward name="b" path="/welcome.jsp" redirect="true" />
</action>
</config>
扩展案例二:
<?xml version="1.0" encoding="UTF-8"?>
<!-- 让其加入其他元素就能报错 -->
<!DOCTYPE web-app [
<!-- 约束 -->
<!ELEMENT web-app (servlet+,servlet-mapping+)>
<!ELEMENT servlet (servlet-name?,servlet-class?)>
<!ELEMENT servlet-mapping (servlet-name,url-pattern+)>
<!ELEMENT servlet-name (#PCDATA) >
<!ELEMENT servlet-class (#PCDATA) >
<!ELEMENT url-pattern (#PCDATA) >
]>
<web-app>
<servlet>
<servlet-name>jrebelServlet</servlet-name>
<servlet-class>com.zking.xml.JrebelServlet</servlet-class>
</servlet>
<servlet>
<servlet-name>jrebelServlet2</servlet-name>
<servlet-class>com.zking.xml.JrebelServlet2</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>jrebelServlet2</servlet-name>
<url-pattern>/jrebelServlet2</url-pattern>
<url-pattern>/jrebelServlet3</url-pattern>
</servlet-mapping>
</web-app>