每个Web应用模块的WEB-INF目录下都有一个web.xml的设定文件,它提供了Web应用项目的配置设定。java
1. 定义头和根元素web
部署描述符文件就像全部的XML文件同样,必须以一个XML头开始。安全
这个XML头生命了可使用的XML版本并给出文件的字符编码,DOCTYPE声明必须当即出如今此头以后。这个声明告诉服务器适用的Servlet规范的版本并指定管理此文件其他部份内容的语法的DTD(Document Type Definition文档类型定义)。服务器
全部的部署描述符文件的顶层(根)元素为web-app。session
XML元素不像HTML,它们是大小写敏感的。app
2. 部署描述符文件内的元素次序工具
XML文件不只是大小写敏感的,并且还对出如今其余元素中的次序敏感。编码
在web-app内,元素的次序也很重要,服务器不必定强制要求这种次序,但它们容许彻底拒绝执行含有次序不正确的元素的web应用。这表示使用非标准元素次序的web.xml文件时不可移植的。spa
下表给出了全部可直接出如今web-app元素内的合法元素所必须的次序,元素是可选的(能够省略),可是不能放在不正确的位置。xml
元素 |
描述 |
icon | 指出IDE和GUI工具用来表示Web应用的一个和两个图像文件的位置 |
display-name | 提供GUI工具可能会用来标记这个特定的Web应用的一个名称 |
description | 给出与此有关的说明性文本 |
context-param | 声明应用范围内的初始化参数 |
filter | 将一个过滤器名字与一个实现javax.servlet.Filter接口的类相关联 |
filter-mapping | 一旦命名了一个过滤器,就要用filter-mapping把它与一个或多个Servlet/Jsp页面相关联 |
listener | Servlet2.3增长监听器支持。事件监听程序在创建/修改和删除会话或Servlet环境时触发,Listener元素指出事件监听程序类 |
servlet | 在向Servlet或JSP页面制定初始化参数或URL时,必须首先命名Servlet或JSP页面,Servlet元素就是用来完成此项任务的 |
servlet-mapping | 通常为servlet提供一个URL,以便Servlet能够访问初始化参数或更容易处理相对URL |
session-config | 可用子元素<session-timeout>设置会话超时值,或经过HttpSession的setMaxInactiveInterval设置 |
mime-mapping | 若是Web应用具备特殊的文件,但愿能保证分配特定的MIME类型,则该元素可提供这种保证 |
welcom-file-list | 指示服务器在收到引用一个目录名而不是文件名的URL时,使用哪一个文件响应 |
error-page | error-page使得在返回特定HTTP状态代码时,或者特定类型的异常被抛出时,可以制定将要显示的页面 |
taglib | 对标记库描述符文件(Tag Library Descriptor file)指定别名,此功能可以更改TLD文件的位置,而不用编辑使用这些文件的JSP页面 |
resource-env-ref | 声明与资源相关的一个管理对象 |
resource-ref | 声明一个资源工厂使用的外部资源 |
security-constraint | 指定应该保护的URL,与login-config元素联合使用 |
login-config | 用login-config元素来指定服务器应该怎样给试图访问受保护页面的用户受权,它与security-constraint元素联合使用 |
security-role | 给出安全角色的列表,这些角色将出如今servlet元素内的security-role-ref元素的role-name子元素中,分别声明角色可以使高级IDE处理安全信息更为容易 |
env-entry | 声明Web应用的环境项 |
ejb-ref | 声明一个EJB主目录的引用 |
ejb-local-ref | 声明一个EJB的本地主目录的应用 |
初始化参数、定制的URL模式以及其余定制经过servlet-name及相似的注册名,而不是类名来引用servlet。可在URL而不是类名中使用此名称。