web.xml 文件也叫部署描述文件。这里简单列举个demo:
这里定义的元素 context-param 我们可以如下方式来获取值:
String value = getServletContext().getInitParameter("name_of_context_initialization_parameter");
这里定义的元素 init-param 我们可以如下方式来获取值:
String value = getServletConfig().getInitParameter("foo");
关于context-param 和 init-param 的加载过程如下:
1.启动一个WEB项目的时候,容器(如:Tomcat)会去读它的配置文件web.xml.读两个节点:
<listener></listener> 和 <context-param></context-param>
2.紧接着,容器创建一个ServletContext(上下文),这个WEB项目所有部分都将共享这个上下文.
3.容器将<context-param></context-param>转化为键值对,并交给ServletContext.
4.容器创建<listener></listener>中的类实例,即创建监听.
5.在监听中会有contextInitialized(ServletContextEvent args)初始化方法,在这个方法中获得
ServletContext = ServletContextEvent.getServletContext();
context-param的值 = ServletContext.getInitParameter("context-param的键");
6.得到这个context-param的值之后,你就可以做一些操作了.注意,这个时候你的WEB项目还没有完全启动完成.这个动作会比所有的Servlet都要早.
换句话说,这个时候,你对<context-param>中的键值做的操作,将在你的WEB项目完全启动之前被执行.
7.举例.你可能想在项目启动之前就打开数据库.那么这里就可以在<context-param>中设置数据库的连接方式,在监听类中初始化数据库的连接.
8.这个监听是自己写的一个类,除了初始化方法,它还有销毁方法.用于关闭应用前释放资源.比如说数据库连接的关闭.
9.... 以上资料来自<<Head First Servlet&JSP>>
session-timeout 元素定义了session 的过期时间
对于常用的 servlet 和 servlet-mapping (将 url 映射到 servlet ,一般为servlet提供一个缺省的URL:http://host/webAppPrefix/servlet/ServletName ) 。
filter 过滤器元素将一个名字与一个实现javax.servlet.Filter接口的类相关联。
security-constraint元素制定应该保护的URL。它与login-config元素联合使用
security-role元素给出安全角色的一个列表,这些角色将出现在servlet元素内的security-role-ref元素的role-name子元素中。分别地声明角色可使高级IDE处理安全信息更为容易。定义了角色具备的访问受控资源权限。
refer :
http://www.javaresearch.org/article/50280.htm