web.xml,部署描写叙述符文件(专业术语)。是在Servlet规范中定义的。是web应用的配置文件(Servlet 3.0已開始放弃使用web.xml,转而使用annotation注解来配置项目)。它通常放置在web项目的WEB-INF文件夹下。
web.xml基本配置(Servlet 2.4):
Servlet2.4Test index.html
注意点:
1. web.xml是一个标准的XML文件,所以它也必须遵循XML的语法规范,即大写和小写敏感,并且在web.xml中全部元素标签都是小写的!2. web.xml对元素的次序敏感
<web-app>
: 顶层(根)元素,用于描写叙述项目使用的Servlet版本号规范、XML版本号、编码等信息(特别注意:假设声明的Servlet版本号与项目使用的真实版本号不一致的话,可能导致用Eclipse打开web.xml卡死的现象),各Servlet版本号的声明例如以下: Servlet2.3:
xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app id="WebApp_ID"> <display-name>Servlet2.3Test</display-name> </web-app>
Servlet2.5:
Servlet2.5Test
Servlet3.0(该版本号已開始推荐使用注解进行web项目配置,但还是能够使用web.xml进行配置):
xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> </web-app>
<icon>
: 指出IDE和GUI工具用来表示Web应用的大图标和小图标,图标必须为GIF或JPEG格式,扩展名必须为.gif或.jpg。<small-icon>
: 小图标,大小为16 X 16 pixel<large-icon>
: 大图标,为32 X 32 pixel。
/images/app_small.gif /images/app_large.gif
<display-name>
: 提供GUI工具可能会用来标记这个特定的Web应用的一个名称。
ServletTest
<disciption>
: 对Web应用进行相关描写叙述说明。
doing some Servlet Test!
<context-param>
: 用于声明应用范围内的初始化參数。在server启动时,容器会将<context-param>
转换为键值对,并交给servletContext,所以能够通过ServletContext对象的getInitParamter()方法来获取该參数值。<param-name>
: 參数名。该值在整个Web应用中必须是惟一的。<param-value>
: 參数值<description >
: 參数描写叙述
test_param_name This is param name test!
JSP中取值方法:${initParam.test_param_name}
Servlet取值方法:String param_name=getServletContext().getInitParamter("test_param_name");
<filter>
: 用于设定web应用的过滤器。能够过滤url或servlet请求。<filter-name>
: 过滤器名称,与<filter-mapping>
的<filter-name>
同样,进行一 一映射。该值在整个Web应用中必须是惟一的。<filter-class>
:过滤类,在指定的请求被过滤器捕获到后。进行相关操作的类,该类必须实现javaxs.servlet.Filter接口。<description>
:过滤器描写叙述说明。<init-param>
: 自己定义配置过滤器相关參数值,能够通过javax.servlet.FilterConfig的getInitParameter(“param-name”)获取到。<param-name>
: 參数名<param-value>
:參数值 -
<filter-mapping>
: 用于声明过滤器要拦截的资源。必须与<filter>
配合使用。filter过滤器的调用顺序是依据
<filter-mapping>
在web.xml中的先后顺序调用的。<filter-name>
:过滤器名称。与<filter-mapping>
的<filter-name>
同样,进行一 一映射。<servlet-name>
:被过滤的servlet名称。<url-pattern>
:被过滤的url。<dispatcher>
: 指定过滤器所拦截的资源被 Servlet 容器调用的方式,能够是REQUEST,INCLUDE,FORWARD和ERROR之中的一个。默认REQUEST。用户能够设置多个<dispatcher>
子元素用来指定 Filter 对资源的多种调用方式进行拦截。
REQUEST:当用户直接訪问页面时,Web容器将会调用过滤器。假设目标资源是通过RequestDispatcher的include()或forward()方法訪问时。那么该过滤器就不会被调用。 INCLUDE:假设目标资源是通过RequestDispatcher的include()方法訪问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。
<dispatcher>
子元素能够设置的值及其意义:FORWARD:假设目标资源是通过RequestDispatcher的forward()方法訪问时。那么该过滤器将被调用,除此之外,该过滤器不会被调用。
ERROR:假设目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。
<listener>
: 用于定义注冊一个监听器类。能够收到事件什么时候发生以及用什么作为响应的通知。<listener-class>
: 监听器类。须包括完整路径。
<servlet>
:声明一个Servlet类<servlet-name>
:servlet名称<servlet-class>
:Servlet类,须包括完整路径。<display-name>
:<description>
: Servlet相关描写叙述说明。<load-on-startup>
:设置Servlet载入的次序。当这个数>=0时,Web容器启动时会按数值从小到大依次载入进内存(实例化此servlet,并调用它的init方法)。假设数值<0或没有指定,则由Web容器决定什么时候载入servlet(Web容器一般会在客户首次訪问这个Servlet时才载入)。配置该属性值能够避免首次Servlet訪问时。载入Servlet导致的响应延迟。
<jsp-file>
:<init-param>
: Servlet相关參数配置。<param-name>
:參数名<param-value>
:參数值<description>
:相关描写叙述说明
<run-as>
: 假设定义了run-as元素,它会重写用于调用Web应用中servlet所设定的Enterprise JavaBean(EJB)的安全身份。<description>
:相关描写叙述说明<role-name>
:为当前Web应用定义的一个安全角色的名称。
<servlet-mapping>
: 将URL模式映射到某个servlet上。<servlet-name>
:servlet名称<url-pattern>
:
<session-config>
:指定javax.servlet.http.HttpSession对象的相关參数。<session-timeout>
:指定默认的session超时时间。单位为分钟,该数值必须为整数。假设
<session-timeout>
元素的值为零或负数,则表示会话将永远不会超时。也能够用HttpSesion的setMaxInactiveInterval()方法设置sesion的时效。
30
<mime-mapping>
:将mime类型映射到扩展名<extension>
:文件扩展名<mime-type>
:MIME类型
doc application/vnd.ms-word xls application/vnd.ms-excel ppt application/vnd.ms-powerpoint
<welcome-file-list>
:<welcome-file>
:用于指定默认首页文件的名称
<error-page>
:<error-code>
:HTTP错误代码<exception-type>
:Java异常类型的全然限定的名称。eg:java.lang.Exception | java.io.IOException | javax.servlet.ServletException …location >
:跳转的路径
404 /error404.jsp java.lang.Exception /exception.jsp
<jsp-config>
:用于JSP的相关配置。该标签为Servlet2.4版本号新增属性<taglib>
:用于自己定义标签库<taglib-uri>
:TLD文件的URI<taglib-location>
:TLD文件在项目中的存放路径
<jsp-property-group>
:Servlet2.4版本号新增属性<description>
: 相关描写叙述说明<display-name>
:<el-ignored>
:是否不支持EL语法,取值:true|false<page-encoding>
:设定JSP页面的编码<scripting-invalid>
:是否不支持<%scription%>语法。取值:true|false<is-xml>
:<icon>
:<small-icon>
:<large-icon>
:
<url-pattern>
:设定值所影响的范围,如:/CH2 或者/*.jsp<include-prelude>
:<include-coda>
:
<resource-env-ref>
:声明与资源相关的一个管理对象<description>
:相关描写叙述说明<env-entry-name>
:<env-entry-type>
:<env-entry-value>
:
<resource-ref>
:<description>
:相关描写叙述说明<res-ref-name>
:与java:comp/env上下文相相应的JNDI名称,在整个Web应用中必须是惟一的。<res-type>
:指明资源类型<res-auth>
:指定管理所引用资源的Manager,取值:Application | Container。Container表示由容器来创建和管理Resource,Application表示由web应用来创建和管理Resource。
<res-sharing-scope>
:能否够共享通过给定资源管理器连接工厂引用获得的连接。取值:Shareable(默认值) | Unshareable。
jdbc/testDataSource javax.sql.DataSource Container
java中获取该JNDI方法:
Context ctx = new InitialContext(); DataSource ds = (DataSource) ctx.lookup("java:comp/env/jndi/testDataSource"); Connection conn = ds.getConnection();
<security-constraint>
:
<login-config>
:设定该web网站四种认证类型<auth-method>
:指定验证方法。取值:BASIC | DIGEST | FORM | CLIENT-CERT。BASIC:HTTP规范,Base64
DIGEST:HTTP规范。数据完整性强一些,但不是SSL CLIENT-CERT:J2EE规范,数据完整性非常强。公共钥匙(PKC) FORM:J2EE规范,数据完整性非常弱。没有加密,同意有定制的登陆界面。<realm-name>
:指定BASIC验证中使用的领域名。<auth-method>
属性配置为BASIC时才有效。<form-login-config>
:指定FORM验证中,相关登陆页面和出错页面。<auth-method>
属性配置为FORM时才有效。<form-login-page>
:定义登陆页面的路径<form-error-page>
:定义出错页面的路径
<security-role>
:
<env-entry>
:’
<ejb-ref>
:
<ejb-local-ref>
:
未完待续!
原文地址: