1、什么是格式良好的XML
2、元素定义
3、属性定义
4、案例
一、什么是格式良好的XML
1、XML的作用
①数据交互
②做配置
2、标准的XML格式
①有且只有一个根元素
②XML标签区分大小写
③正确使用结束标签
④正确嵌套标签
⑤使用了合法的标签名
⑥定义有效的属性
二、元素定义
1、在XML加入DTD声明
2、元素的分类
①空元素:<!ELEMENT element-name EMPTY>
②文本元素:<!ELEMENT element-name (#PCDATA)>
③混合元素:<!ELEMENT element-name (e1,e2)>
3、元素的限制
①和(,)或者(|)
②次数:
0或1:?
0~N:*
1~N:+
代码展示:
<?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没有子标签,有内容 文本标签
<!DOCTYPE root [...]>
ctrl+shift+x:将小写转为大写
-->
<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>
三、属性定义
1、语法
<!ATTLIST person pid ID #REQUIRED>2、属性类型type
①ID
②(男|女)
③CDATA
④IDREF
⑤reference
3、属性描述
①#REQUIRED:必填
②#IMPLIED:非必填
③‘默认值’:只有类型为(男|女)时,才可以用默认方式
代码展示:
<?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>
<!--
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>
四、案例
1、案例1:
代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<!--
config标签:可以包含0~N个action标签
-->
<!DOCTYPE config [
<!ELEMENT config (action*)>
<!ELEMENT action (forward*)>
<!ATTLIST action
path CDATA #REQUIRED
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>
2、案例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+)>
]>
<web-app>
<servlet>
<servlet-name>jrebelServlet</servlet-name>
<servlet-class>com.xnx.xml.JrebelServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>jrebelServlet</servlet-name>
<url-pattern>/jrebelServlet</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>jrebelServlet2</servlet-name>
<servlet-class>com.xnx.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>