1.DTD简介
- DTD用于约束xm的文档格式,保证xml是一个有效的xml(也就是说在xml中引入DTD约束让别人不能在xml中随便写入内容)
- DTD可以分为 内部DTD,外部DTD
2.什么是XML
- XML 是可扩展标记语言
- XML 是一种很像HTML的标记语言。
- XML 的设计宗旨是传输数据。
2.1.XML 用途
- XML 应用于 Web 开发方面,常用于简化数据的存储和传输
- 文件配置
2.2 标准的XML格式特点
- 有且只要一个根元素
- xml标签大小写区分
- 正确使用结束标签
- 正确嵌套标签
- 使用合法标签
- 定义有效属性
3.DTD写法及规则
内部DTD定义语法:<!DOCTYPE 根元素 [ 元素声明 ]>
3.1元素定义
元素定义格式 <!ELEMENT 元素名 元素类型>
- <!ELEMENT 元素名 EMPTY> ----空元素
- <!ELEMENT 元素名 (#PCDATA)> ----文本元素
- <!ELEMENT 元素名 (元素1,元素2)> ---混合元素
3.2 元素个数限制
- ? 0或1个
- * 0到多个
- + 1到多个
- (,) 与 (|)非
案例1:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE persons [
<!ELEMENT persons (person+) >
<!ELEMENT person (name,age,contact,br?) >
<!ELEMENT contact (phone|email) >
<!ELEMENT name (#PCDATA) >
<!ELEMENT age (#PCDATA) >
<!ELEMENT phone (#PCDATA) >
<!ELEMENT email (#PCDATA) >
<!ELEMENT br EMPTY >
]>
<persons><!-- 根元素 -->
<person>
<name>张小明</name>
<age>10</age>
<contact>
<phone>1234567</phone>
</contact>
<br/>
</person>
<person>
<name>张大明</name>
<age>35</age>
<contact>
<email>123@qq.com</email>
</contact>
</person>
</persons>
案列2 :
<?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>jrebelServlet</servlet-name>
<url-pattern>/jrebelServlet</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>jrebelServlet2</servlet-name>
<url-pattern>/jrebelServlet2</url-pattern>
<url-pattern>/jrebelServlet3</url-pattern>
</servlet-mapping>
</web-app>
3.3 属性定义
属性定义格式 <!ATTLIST 元素名 属性名 属性类型 描述>(属性是属于元素的,所以定义属性一定要定义元素)
属性类型
- ID id类别
- (男|女) 选项类别
- CDATA 文本类别
- IDREF 依赖类别
属性描述
- #REQUIRED 必填
- # IMPLIED 非必填
- ‘ 默认值 ’ (只要选项类别才能使用默认值描述)
案列3:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE persons [
<!ELEMENT persons (person+)>
<!ELEMENT person (name,age,contact,br?) >
<!ELEMENT contact (phone|email)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT age (#PCDATA)>
<!ELEMENT phone (#PCDATA)>
<!ELEMENT email (#PCDATA)>
<!ELEMENT br EMPTY>
<!-- 属性定义 -->
<!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>
案列4:
<?xml version="1.0" encoding="UTF-8"?>
<!--
config标签:可以包含0~N个action标签
-->
<!DOCTYPE config [
<!ELEMENT config (action*) >
<!ELEMENT action (forward*) >
<!ELEMENT forward EMPTY >
<!ATTLIST forward
name ID #REQUIRED
path CDATA #IMPLIED
redirect (true|false) 'true'
>
<!ATTLIST action
path CDATA #IMPLIED
type CDATA #REQUIRED
>
]>
<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>