ServletContextListener使用详解
在 Servlet API 中有一个 ServletContextListener 接口,它能够监听 ServletContext 对象的生命周期,实际上就是监听 Web 应用的生命周期。
当Servlet 容器启动或终止Web 应用时,会触发ServletContextEvent 事件,该事件由ServletContextListener 来处理。在 ServletContextListener 接口中定义了处理ServletContextEvent 事件的两个方法。
- /**
 - * 当Servlet 容器启动Web 应用时调用该方法。在调用完该方法之后,容器再对Filter 初始化,
 - * 并且对那些在Web 应用启动时就需要被初始化的Servlet 进行初始化。
 - */
 - contextInitialized(ServletContextEvent sce)
 - /**
 - * 当Servlet 容器终止Web 应用时调用该方法。在调用该方法之前,容器会先销毁所有的Servlet 和Filter 过滤器。
 - */
 - contextDestroyed(ServletContextEvent sce)
 
下面通过两个具体的例子来介绍 ServletContextListener 的用法。
例一:在服务启动时,将数据库中的数据加载进内存,并将其赋值给一个属性名,其它的 Servlet 就可以通过 getAttribute 进行属性值的访问。
有如下两个步骤:
1 : ServletContext 对象是一个为整个 web 应用提供共享的内存,任何请求都可以访问里面的内容
2 :如何实现在服务启动的时候就动态的加入到里面的内容:我们需要做的有:
1 ) 实现 servletContextListerner 接口 并将要共享的通过 setAttribute ( name,data )方法提交到内存中去 ;
2 )应用项目通过 getAttribute(name) 将数据取到 。
- public class ServletContextLTest implements ServletContextListener{
 - // 实现其中的销毁函数
 - public void contextDestroyed(ServletContextEvent sce) {
 - System.out.println("this is last destroyeed");
 - }
 - // 实现其中的初始化函数,当有事件发生时即触发
 - public void contextInitialized(ServletContextEvent sce) {
 - ServletContext sct=sce.getServletContext();
 - Map<Integer,String> depts=new HashMap<Integer,String>();
 - Connection connection=null;
 - PreparedStatement pstm=null;
 - ResultSet rs=null;
 - try{
 - connection=ConnectTool.getConnection();
 - String sql="select deptNo,dname from dept";
 - pstm=connection.prepareStatement(sql);
 - rs=pstm.executeQuery();
 - while(rs.next()){
 - depts.put(rs.getInt(1), rs.getString(2));
 - }
 - // 将所取到的值存放到一个属性键值对中
 - sct.setAttribute("dept", depts);
 - System.out.println("======listener test is beginning=========");
 - }catch(Exception e){
 - e.printStackTrace();
 - }finally{
 - ConnectTool.releasersc(rs, pstm, connection);
 - }
 - }
 - }
 
在完成上述编码后,仍需在 web.xml 中进行如下配置,以使得该监听器可以起作用。
- <listener>
 - <listener-class>ServletContextTest.ServletContextLTest</listener-class>
 - </listener>
 
在完成上述配置后, web 服务器在启动时,会直接加载该监听器,通过以下的应用程序就可以进行数据的访问。
- public class CreateEmployee extends HttpServlet{
 - @Override
 - protected void service(HttpServletRequest request, HttpServletResponse response)
 - throws ServletException, IOException {
 - ServletContext sct=getServletConfig().getServletContext();
 - // 从上下文环境中通过属性名获取属性值
 - Map<Integer,String> dept=(Map<Integer,String>)sct.getAttribute("dept");
 - Set<Integer> key=dept.keySet();
 - response.setContentType("text/html;charset=utf-8");
 - PrintWriter out=response.getWriter();
 - out.println("<html>");
 - out.println("<body>");
 - out.println("<form action='/register' action='post'>");
 - out.println("<table alignb='center'>");
 - out.println("<tr>");
 - out.println("<td>");
 - out.println("username:");
 - out.println("</td>");
 - out.println("<td>");
 - out.println("<input type='text' name='username'");
 - out.println("</tr>");
 - out.println("<tr>");
 - out.println("<td>");
 - out.println("city:");
 - out.println("</td>");
 - out.println("<td>");
 - out.println("<select name='dept'");
 - for(Integer i:key){
 - out.println("<option value='"+i+"'>"+dept.get(i)+"</option>");
 - }
 - out.println("</select>");
 - out.println("</td>");
 - out.println("<tr>");
 - out.println("</table>");
 - out.println("</form>");
 - out.println("</body>");
 - out.println("</html>");
 - out.flush();
 - }
 - }
 
例二:书写一个类用于统计当Web 应用启动后,网页被客户端访问的次数。如果重新启动Web 应用,计数器不会重新从1 开始统计访问次数,而是从上次统计的结果上进行累加。
在实际应用中,往往需要统计自Web 应用被发布后网页被客户端访问的次数,这就要求当Web 应用被终止时,计数器的数值被永久存储在一个文件中或者数据库中,等到Web 应用重新启动时,先从文件或数据库中读取计数器的初始值,然后在此基础上继续计数。
向文件中写入或读取计数器的数值的功能可以由自定义的 MyServletContextListener 类来完成,它具有以下功能:
1 、在 Web 应用启动时从文件中读取计数器的数值,并把表示计数器的 Counter 对象存放到 Web应用范围内。存放计数器的文件的路径为helloapp/count/count.txt 。
2 、在Web 应用终止时把Web 应用范围内的计数器的数值保存到count.txt 文件中。
- public class MyServletContextListener implements ServletContextListener{
 - public void contextInitialized(ServletContextEvent sce){
 - System.out.println("helloapp application is Initialized.");
 - // 获取 ServletContext 对象
 - ServletContext context=sce.getServletContext();
 - try{
 - // 从文件中读取计数器的数值
 - BufferedReader reader=new BufferedReader(
 - new InputStreamReader(context.
 - getResourceAsStream("/count/count.txt")));
 - int count=Integer.parseInt(reader.readLine());
 - reader.close();
 - // 创建计数器对象
 - Counter counter=new Counter(count);
 - // 把计数器对象保存到 Web 应用范围
 - context.setAttribute("counter",counter);
 - } catch(IOException e) {
 - e.printStackTrace();
 - }
 - }
 - public void contextDestroyed(ServletContextEvent sce){
 - System.out.println("helloapp application is Destroyed.");
 - // 获取 ServletContext 对象
 - ServletContext context=sce.getServletContext();
 - // 从 Web 应用范围获得计数器对象
 - Counter counter=(Counter)context.getAttribute("counter");
 - if(counter!=null){
 - try{
 - // 把计数器的数值写到 count.txt 文件中
 - String filepath=context.getRealPath("/count");
 - filepath=filepath+"/count.txt";
 - PrintWriter pw=new PrintWriter(filepath);
 - pw.println(counter.getCount());
 - pw.close();
 - } catch(IOException e) {
 - e.printStackTrace();
 - }
 - }
 - }
 - }
 
将用户自定义的 MyServletContextListener 监听器在 Servlet 容器进行注册, Servlet 容器会在启动或终止 Web 应用时,会调用该监听器的相关方法。在 web.xml 文件中, <listener> 元素用于向容器注册监听器:
- <listener>
 - <listener-class> ServletContextTest .MyServletContextListener<listener-class />
 - </listener>
 
通过上述两个例子,即可以非常清楚的了解到 ServletContextListener 接口的使用方法及技巧。
在Container 加载Web 应用程序时(例如启动 Container 之后),会呼叫contextInitialized() ,而当容器移除Web 应用程序时,会呼叫contextDestroyed () 方法。
通过 Tomcat 控制台的打印结果的先后顺序,会发现当 Web 应用启动时,Servlet 容器先调用contextInitialized() 方法,再调用lifeInit 的init() 方法;
当Web 应用终止时,Servlet 容器先调用lifeInit 的destroy() 方法,再调用contextDestroyed() 方法。
由此可见,在Web 应用的生命周期中,ServletContext 对象最早被创建,最晚被销毁。
原文地址:http://blog.csdn.net/zhaozheng7758/archive/2010/12/28/6103700.aspx
ServletContextListener使用详解的更多相关文章
- ServletContextListener使用详解(监听Tomcat启动、关闭)
		
在 Servlet API 中有一个 ServletContextListener 接口,它能够监听 ServletContext 对象的生命周期,实际上就是监听 Web 应用的生命周期. 当Serv ...
 - Web.xml详解(转)
		
这篇文章主要是综合网上关于web.xml的一些介绍,希望对大家有所帮助,也欢迎大家一起讨论. ---题记 一. Web.xml详解: (一) web.xml加载过程(步骤) 首 ...
 - java web.xml配置详解(转)
		
源出处:java web.xml配置详解 1.常规配置:每一个站的WEB-INF下都有一个web.xml的设定文件,它提供了我们站台的配置设定. web.xml定义: .站台的名称和说明 .针对环境参 ...
 - web.xml配置详解之listener
		
web.xml配置详解之listener 定义 <listener> <listener-class>nc.xyzq.listener.WebServicePublishLis ...
 - 《Tomcat与Java Web开发技术详解》思维导图
		
越想构建上层建筑,就越觉得底层基础很重要.补课系列. 书是良心书,就是太基础了,正适合补课. [纯文字版] Tomcat与Java Web开发技术详解 Servlet Servlet的生命周期 初始化 ...
 - jboss之启动加载过程详解
		
今天看了看jboss的boot.log和server.log日志,结合自己的理解和其他的资料,现对jboss的启动和加载过程做出如下总结: boot.xml是服务器的启动过程的日志,不涉及后续的操作过 ...
 - Mybatis案例超详解(上)
		
Mybatis案例超详解(上) 前言: 本来是想像之前一样继续跟新Mybatis,但由于种种原因,迟迟没有更新,快开学了,学了一个暑假,博客也更新了不少,我觉得我得缓缓,先整合一些案例练练,等我再成熟 ...
 - Web.xml配置详解(转)
		
Web.xml配置详解 Posted on 2010-09-02 14:09 chinaifne 阅读(295105) 评论(16) 编辑 收藏 1 定义头和根元素 部署描述符文件就像所有XML文件一 ...
 - Linq之旅:Linq入门详解(Linq to Objects)
		
示例代码下载:Linq之旅:Linq入门详解(Linq to Objects) 本博文详细介绍 .NET 3.5 中引入的重要功能:Language Integrated Query(LINQ,语言集 ...
 
随机推荐
- 【opencv学习笔记】SetImageROI函数设置ROI区域的作用及用法
			
虽然先前知道ROI区域是感兴趣区域,但是真正看到调用了OpenCV的cvSetImageROI函数时,并不知道它的作用,所以还是单独写了一段代码对这个函数进行探究. OpenCVchm文档中对cv ...
 - 《Java中的包机制》
			
/* 包的机制:(1) */ package lee; public class PackageTest { public void Test(int num) { System.out.printl ...
 - css2----实现三角形和带角框
			
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
 - javascript的异步编程方法
			
一,callback 回调函数 即函数f1和函数f2的关系是f1(f2()); f2作为f1()的回调函数,在f1执行过程中就开始执行f2,先执行线程的主要逻辑,将比较耗时的任务放在后面执行. 回调函 ...
 - C语言使用cmd命令并获取输出方法
			
转自http://blog.csdn.net/hxh129/article/details/8000205 C语言使用cmd命令并获取输出方法 在实践中,我们有时候需要用C语言来调用cmd的命令,并得 ...
 - 加入Tomcat插件到ECLIPSE中的方法
			
1.下载Tomcat插件com.sysdeo.eclipse.tomcat_3.3.1.jar 下载路径http://www.eclipsetotale.com/ 2.安装插件 把下载的插件放到E:\ ...
 - Mybatis开篇以及配置教程
			
MyBatis来源~: MyBatis本是apache的一个开源的项目,原来称为iBatis,2010年这个项目由apache softwarefoundation迁移到了google code,并改 ...
 - Adroid 总结--android ListView美化,个性化更改的属性
			
首先是stackFromBottom属性,这只该属性之后你做好的列表就会显示你列表的最下面,值为true和falseandroid:stackFromBottom="true" ...
 - WampServe修改默认网站目录的方法(转)
			
1wamp简介 WampServe集成了Apache.MySQL.PHP.phpmyadmin,支持Apache的mod_rewrite,PHP扩展.Apache模块只需要在菜单“开启/关闭”上点点就 ...
 - HDU 2509 nim博弈
			
Be the Winner Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...