DTD约束

本文详细介绍了XML中的DTD(文档类型定义),包括内部和外部申明、元素定义语法、属性定义语法以及特殊符号转义。示例展示了如何在web-app配置中使用DTD来定义元素和属性,如display-name、context-param、listener、filter等,以确保XML文档结构的合法性。同时,文中还提及了Spring与web项目的集成配置,如context-param、CharacterEncodingFilter和DispatcherServlet的配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.什么是DTD?
文档类型定义 (document type definition) (约束)


2.使用DTD

在XML中加入DTD申明
        1)内部申明:<!DOCTYPE root[]>
    2)外部申明:<!DOCTYPE 文档根节点 SYSTEM(PUBLIC) “DTD文件名”>

元素定义语法(DTD对元素的限制)
        基本语法:<!ELEMENT 元素名称 元素类型 >

        元素分类:EMPTY     空元素      <br/>
                          (#PCDATA)  文本元素   
                          (e1,e2)    混合元素

      元素限制:,(顺序)、|(或,多选一)、?(0或1次),*(1*0=0,0次或多次), +(1+0=1,1次或多次)

      属性定义语法(DTD对属性的限制)
      基本语法:<!ATTLIST 元素名称 属性名称 属性类型 设置说明>
    
    属性类型:ID/CDATA/ENUM (男|女) "男" IDREF

    设置说明:#REQUIRED(必须)/#IMPLIED(可选)

特殊符号转义
    &(逻辑与)      -->  &amp;
    >(大于)     -->  &gt;
    <(小于)     -->  &lt;
    ‘(单引号)     -->  &apos;
    “(双引号)     -->  &quot;

<?xml version="1.0" encoding="UTF-8"?>
//web-app 是跟目录
<!DOCTYPE web-app[
        <!ELEMENT web-app (display-name,context-param,listener+,filter,filter-mapping,servlet,servlet-mapping,welcome-file-list) >
        <!ELEMENT display-name (#PCDATA)>
        <!ELEMENT context-param (param-name,param-value)>
        <!ELEMENT param-value (#PCDATA)>
        <!ELEMENT param-name (#PCDATA)>
        <!ELEMENT listener (listener-class)>
        <!ELEMENT listener-class (#PCDATA)>
        <!ELEMENT filter (filter-name,filter-class,async-supported,init-param)>
        <!ELEMENT filter-name (#PCDATA)>
        <!ELEMENT filter-class (#PCDATA)>
        <!ELEMENT async-supported (#PCDATA)>
        <!ELEMENT init-param (param-name,param-value)>
        <!ELEMENT filter-mapping (filter-name,url-pattern)>
        <!ELEMENT url-pattern (#PCDATA)>
        <!ELEMENT servlet (servlet-name,servlet-class,init-param,load-on-startup,async-supported)>
        <!ELEMENT servlet-name (#PCDATA)>
        <!ELEMENT servlet-class (#PCDATA)>
        <!ELEMENT load-on-startup (#PCDATA)>
        <!ELEMENT servlet-mapping (servlet-name,url-pattern)>
        <!ELEMENT welcome-file-list (welcome-file)>
        <!ELEMENT welcome-file (#PCDATA)>
]>
<web-app>
  <display-name>Archetype Created Web Application</display-name>
  <!-- Spring和web项目集成start -->
  <!-- spring上下文配置文件 -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
  </context-param>
  <!-- 读取Spring上下文的监听器 -->
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <!-- Spring和web项目集成end -->

  <!-- 防止Spring内存溢出监听器 -->
  <listener>
    <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
  </listener>

  <!-- 中文乱码处理 -->
  <filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <async-supported>true</async-supported>
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

  <!-- Spring MVC servlet -->
  <servlet>
    <servlet-name>SpringMVC</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <!--此参数可以不配置,默认值为:/WEB-INF/springmvc-servlet.xml-->
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>/WEB-INF/spring-mvc.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
    <!--web.xml 3.0的新特性,是否支持异步-->
    <async-supported>true</async-supported>
  </servlet>
  <servlet-mapping>
    <servlet-name>SpringMVC</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

  <welcome-file-list>
    <welcome-file>/home/index.shtml</welcome-file>
  </welcome-file-list>
</web-app>

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值