Set集合

XML-DTD约束

设计模式

它是用来解决现实中出现的一类问题,固定的解决方案,Java的解决方案23中 被统称为23种设计模式

框架的由来

就是由多种设计模式配合形成的
特定的框架处理特定问题
底层是通过Java的反射机制来完成

关于XML

1. 什么是格式良好XML

  1.1 有且只有一个根元素
      有两个元素会报错
  1.2 XML标签大小写正确区分
  1.3 正确使用结束标签
 
      结束标签需要正确结束 不然它会和最近的标签进行匹配
  1.4 正确嵌套标签
  1.5 使用了合法的标签名
  1.6 定义有效的属性

如下代码:

<?xml version="1.0" encoding="UTF-8"?>
<students>
	<student>
		<name>乌龟</name>
		<age>10</age>
		<contact>
			<phone>1234567</phone>
		</contact>
		<br/>
	</student>
	<student>
		<name>状元</name>
		<age>35</age>
		<contact>
			<email>123@qq.com</email>
		</contact>
	</student>
</students>

2. 在XML加入DTD声明

<!DOCTYPE root[]>

3. 元素定义的语法

   <!ELEMENT element-name (type)>
   注:根标签也要定义!!!

4. 元素的分类

   <!ELEMENT element-name EMPTY>//空元素
   <!ELEMENT element-name (#PCDATA)>//文本元素
   <!ELEMENT element-name (e1,e2)>//混合元素

5. 元素的限制

   ,
   |
   次数: +, 1~n
         *, 0~n
         ?, 01
        没有	

如下示例

  <!DOCTYPE students[
      <!ELEMENT students (student*)> <!-- 定义元素(根元素) 内容为student元素  *表示0-n-->
      <!ELEMENT student (name,age,contact,br?)> <!-- 定义元素student 内容以次为name,age,contact,br ?表示01 -->
      <!ELEMENT name (#PCDATA)> <!--定义元素name,内容为纯文本 -->
      <!ELEMENT age (#PCDATA)> <!--定义元素age,内容为纯文本 -->
      <!ELEMENT contact (phone|email)> <!--定义元素contact,内容为phone或email元素  | 表示或者  -->
      <!ELEMENT phone (#PCDATA)> <!--定义元素phone,内容为纯文本 -->
      <!ELEMENT email (#PCDATA)> <!--定义元素email,内容为纯文本 -->
      <!ELEMENT br EMPTY> <!--定义元素br,内容为空,即为空元素,可以拥有属性 -->
    ]>

6. 属性定义的语法
如以下代码:

 <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE students[
      <!ELEMENT students (student*)> <!-- 定义元素(根元素) 内容为student元素  *表示0-n-->
      <!ELEMENT student (name,age,contact,br?)> <!-- 定义元素student 内容以次为name,age,contact,br ?表示01 -->
      <!ELEMENT name (#PCDATA)> <!--定义元素name,内容为纯文本 -->
      <!ELEMENT age (#PCDATA)> <!--定义元素age,内容为纯文本 -->
      <!ELEMENT contact (phone|email)> <!--定义元素contact,内容为phone或email元素  | 表示或者  -->
      <!ELEMENT phone (#PCDATA)> <!--定义元素phone,内容为纯文本 -->
      <!ELEMENT email (#PCDATA)> <!--定义元素email,内容为纯文本 -->
      <!ELEMENT br EMPTY> <!--定义元素br,内容为空,即为空元素,可以拥有属性 -->
    
      <!ATTLIST student
          pid ID #REQUIRED
          sex (|) '男'
          qq CDATA #IMPLIED
          parent IDREF
      >
    
    ]>
    <students>
    	<student pid="p1" sex="男" qq="aaa" parent="p2">
    		<name>张小明</name>
    		<age>10</age>
    		<contact>
    			<phone>1234567</phone>
    		</contact>
    		<br/>
    	</student>
    	<student pid="p2">
    		<name>张大明</name>
    		<age>35</age>
    		<contact>
    			<email>123@qq.com</email>
    		</contact>
    	</student>
    </students>

其中ATTLIST是attributelist的缩写,也就是属性集合
如果有属性但是没定义 代码中的属性就会报错

以下是属性类别的选项

7. 关于XML中的特殊符号

   &(逻辑与)  &amp;        
   <(小于)    &lt;        
   >(大于)    &gt;        
   "(双引号)  &quot;      
   '(单引号)  &apos;

Config案例:

   <?xml version="1.0" encoding="UTF-8"?>
    	<!DOCTYPE config[
      <!ELEMENT config (action*)><!--config标签:可以包含0~n个action标签  -->
      <!ELEMENT action (forward*)><!-- action标签:可以饱含0~n个forward标签 -->
      <!ELEMENT foward EMPTY>
      <!--path:以/开头的字符串,并且值必须唯一 非空 ,子控制器对应的路径  -->
      <!-- type:字符串,非空,子控制器的完整类名 -->
      <!ATTLIST action 
          path CDATA #REQUIRED
          type CDATA #REQUIRED
      >
      <!ATTLIST forward
          name CDATA #REQUIRED
          path CDATA #REQUIRED
          redirect (true|false) 'true'
      >
    ]>
    
    <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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值