2、web.xml文件元素详解
  下面的列表给出了所有可直接出现在web-app元素内的合法元素的次序。例如,此列表说明servlet元素必须出现在所有servlet-mapping元素之 前。请注意,所有这些元素都是可选的。
 
    (1)  <icon>Web应用图标      
      指出IDE和GUI工具用来表示Web应用的
应用的大图标和小图标
的位置
 
      
      <icon>
        <small-icon>/images/app_small.gif</small-icon>
        <large-icon>/images/app_large.gif</large-icon>
      </icon>
    (2) <display-name> Web应用名称
      提供GUI工具可能会用来标记这个特定的Web应用的一个名称
      <display>my webapp</display>
      
    (3) <description> Web应用说明
      给出于此相关的说明性文本
      <description> This is my first webapp</description>
 
    (4) <context-param>上下文参数
      声明应用范围内的初始化参数。它用于向 ServletContext提供键值对,即应用程序上下文信息。我们的listener, filter等在初始化时会用到这些上下文中的信息。在servlet里面可以通过getServletContext().getInitParameter("context/param")得到。
 
    <context-param>
      <param-name>ContextParameter</param-name>
      <param-value>test</param-value>
      <description>It is a test parameter.</description>
    </context-param>
 
    (5) <filter> and <filter-mapping> 过滤器
      <filter> 将一个名字与一个实现javaxs.servlet.Filter接口的类相关联
      <filter-mapping> 一旦命名了一个过滤器,就要利用filter-mapping元素把它与一个或多个servlet或JSP页面相关联。
 
      <filter>
        <filter-name>myTestFilter</filter-name>
        <filter-class>com.myTest.MyTestFilter</filter-class>
      </filter>
      <filter-mapping>
        <filter-name>myTestFilter<filter-name>
        <url-pattern>/*</url-pattern>
      </filter-mapping>
     (6) <listener> 监听器
        将一个名字与一个实现了相应Listener接口的类相关联
        servlet API的版本2.3增加了对事件监听程序的支持,事件监听程序在建立、修改和删除会话或servlet环境时得到通知。Listener元素指出事件监听程序类。  
      <listener>        
        <listener-class>com.listener.SessionListener</listener-class>
      </listener>
     (7) <servlet> and <servlet-mapping> 定制URL
        在向servlet或JSP页面制定初始化参数或定制URL时,必须首先命名servlet或JSP页面。Servlet元素就是用来完成此项任务的。
        服务器一般为servlet提供一个缺省的URL:
"http://host/webAppPrefix/servlet/ServletName">http://host/webAppPrefix/servlet/ServletName</a>。但是,常常会更改这个URL,以便servlet可以访问初始化参数或更容易地处理相对URL。在更改缺省URL时,使用servlet-mapping元素。
        
    <servlet></servlet> 用来声明一个servlet的数据,主要有以下子元素:
      a. <servlet-name></servlet-name> 指定servlet的名称
      b. <servlet-class></servlet-class> 指定servlet的类名称
      c. <jsp-file></jsp-file> 指定web站台中的某个JSP网页的完整路径
      d. <init-param></init-param> 用来定义参数,可有多个init-param。在servlet类中通过getInitParamenter(String name)方法访问初始化参数
      e. <load-on-startup></load-on-startup>指定当Web应用启动时,装载Servlet的次序。当值为正数或零时:Servlet容器先加载数值小的servlet,再依次加载其他数值大的servlet。当值为负或未定义:Servlet容器将在Web客户首次访问这个servlet时加载它。
      f. <servlet-mapping></servlet-mapping> 用来定义servlet所对应的URL,包含两个子元素
      g. <servlet-name></servlet-name> 指定servlet的名称
      h. <url-pattern></url-pattern> 指定servlet所对应的URL
      <servlet>
        <servlet-name>testServlet</servlet-name>
        <servlet-class>com.testservlet.TestServlet</servlet-class>
      </servlet>
      <servlet-mapping>
         <servlet-name>testServlet</servlet-name>
          <url-pattern>/test/testServlet</url-pattern>
      </servlet-mapping>
     (8) <session-config> 会话超时配置 (单位:分钟) 
        如果某个会话在一定时间内未被访问,服务器可以抛弃它以节省内存。可通过使用HttpSession的setMaxInactiveInterval方法 明确设置单个会话对象的超时值,或者可利用session-config元素制定缺省超时值。 
      <session-config>
        <session-timeout>120</session-timeout>
      </session-config>
     
     (9): <mime-mapping> 
        如果Web应用具有想到特殊的文件,希望能保证给他们分配特定的MIME类型,则mime-mapping元素提供这种保证
 
       <mime-mapping>
        <extension>htm</extension>
        <mime-type>text/html</mime-type>
      </mime-mapping>
 
     (10)  <welcome-file-list>欢迎文件页
        指示服务器在收到引用一个目录名而不是文件名的URL时,使用哪个文
        <welcome-file-list>
          <welcome-file>index.jsp</welcome-file>
          <welcome-file>index.html</welcome-file>
          <welcome-file>index.htm</welcome-file>
        </welcome-file-list>
 
     (11) <error-page> 错误页面
        使得在返回特定HTTP状态代码时,或者特定类型的异常被抛出时,能够制定将要显示的页面。
        <error-page>
          <error-code>404</error-code>
          <location>/NotFound.jsp</location>
        </error-page>
        
        <error-page>
          <error-type>java.lang.NullException</error-type>
          <location>/error.jsp</location>
        </error-page>
 
 
     (12) <jsp-config>设置jsp
      <jsp-config> 包括 <taglib> 和 <jsp-property-group> 两个子元素。其中<taglib> 元素在JSP 1.2 时就已经存在;而<jsp-property-group> 是JSP 2.0 新增的元素。
      <taglib>元素对标记库描述符文件(Tag Libraryu Descriptor file)指定别名。此功能使你能够更改TLD文件的位置,而不用编辑使用这些文件的JSP页面。  
<jsp-property-group> 元素主要有八个子元素,它们分别为:
- <description>:设定的说明 
 
- <display-name>:设定名称 
 
- <url-pattern>:设定值所影响的范围,如: /CH2 或 /*.jsp
 
- <el-ignored>:若为 true,表示不支持 EL 语法 
 
- <scripting-invalid>:若为 true,表示不支持 <% scripting %>语法 
 
- <page-encoding>:设定 JSP 网页的编码 
 
- <include-prelude>:设置 JSP 网页的抬头,扩展名为 .jspf
 
- <include-coda>:设置 JSP 网页的结尾,扩展名为 .jspf  
 
   对于Web 应用程式来说,Scriptlet 是个不乐意被见到的东西,因为它会使得HTML 与Java 程式码交相混杂,对于程式的维护来说相当的麻烦,必要的时候,可以在web.xml 中加上<script-invalid> 标签,设定所有的JSP 网页都不可以使用Scriptlet。
  <jsp-config>
    <taglib>
              <taglib-uri>Taglib</taglib-uri>
              <taglib-location>/WEB-INF/tlds/MyTaglib.tld</taglib-location>
        </taglib>
        <jsp-property-group>
              <description>Special property group for JSP Configuration JSP example.</description>
              <display-name>JSPConfiguration</display-name>
              <url-pattern>/jsp/* </url-pattern>
              <el-ignored>true</el-ignored>
              <page-encoding>GB2312</page-encoding>
              <scripting-invalid>true</scripting-invalid>
              <include-prelude>/include/prelude.jspf</include-prelude>
              <include-coda>/include/coda.jspf</include-coda>
        </jsp-property-group>
   </jsp-config>
 
      (13) <resource-env-ref>
        指定对管理对象的servlet引用的声明,该对象与servlet环境中的资源相关联     
      <resource-env-ref>  
        <resource-env-ref-name>资源名</resource-env-ref-name>  
        <resource-env-ref-type>查找资源时返回的资源类名</resource-env-ref-type>   
       </resource-env-ref> 
        <resource-env-ref-name>:资源的名称 相对于
Java:comp/env >>context
 
        <resource-env-ref-type>:当web应用查找该资源的时候,返回的Java类名的全称
     (14) <resource-ref>
        声明一个资源工厂使用的外部资源
 
     (15) <security-constraint>
        制定应该保护的URL。它与login-config元素联合使用 
 
     (16) <login-config>
        用login-config元素来指定服务器应该怎样给试图访问受保护页面的用户授权。它与sercurity-constraint元素联合使用    
 
     (17) <security-role>
        security-role元素给出安全角色的一个列表,这些角色将出现在servlet元素内的security-role-ref元素的role-name子元素中。分别地声明角色可使高级IDE处理安全信息更为容易。
  
     (18) <env-entry>
        env-entry元素声明Web应用的环境项
     
      (19) <ejb-ref>
        ejb-ref元素声明一个EJB的主目录的引用
      
        ejb-local-ref元素声明一个EJB的本地主目录的应用