tomcat 服务器的几个重要监听 方法 与 使用

Posted c2g5201314

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了tomcat 服务器的几个重要监听 方法 与 使用相关的知识,希望对你有一定的参考价值。

1.

总结一下tomcat 服务器里的三种监听

ServletContextListener

HttpSessionListener

ServletRequestListener

 

这是我要做的三个自定义重写 类 分别继承上面三个接口

技术图片

 

2具体源码

 

 

(1) ServletContextListener  

用于监听服务器的启动与关闭

技术图片
 1 package cn.cen2guo.clinic.listener;
 2 
 3 
 4 import javax.servlet.ServletContextEvent;
 5 import javax.servlet.ServletContextListener;
 6 
 7 
 8 /**
 9  * 用于监听服务器的启动与关闭
10  */
11 public class MyServletContextListener implements ServletContextListener {
12     @Override
13     public void contextInitialized(ServletContextEvent sce) {
14 //        System.out.println("创建ServletContext对象");
15     }
16 
17     @Override
18     public void contextDestroyed(ServletContextEvent sce) {
19 //        System.out.println("销毁ServletContext对象");
20     }
21 }
MyServletContextListener

 

(2) HttpSessionListener

用于监听session的创建与销毁

技术图片
 1 package cn.cen2guo.clinic.listener;
 2 
 3 
 4 import javax.servlet.http.HttpSessionEvent;
 5 import javax.servlet.http.HttpSessionListener;
 6 
 7 /**
 8  * 用于监听session的创建于销毁,目前没啥用处
 9  */
10 
11 public class MyHttpSessionListener implements HttpSessionListener {
12 
13     @Override
14     public void sessionCreated(HttpSessionEvent se) {
15 //        System.out.println("session 被创建了");
16 //        System.out.println(se.getSession().getId());
17     }
18 
19     @Override
20     public void sessionDestroyed(HttpSessionEvent se) {
21 //        System.out.println("session 被销毁了");
22 //        System.out.println(se.getSession().getId());
23 //        System.out.println("销毁结束");
24     }
25 
26 
27 }
MyHttpSessionListener

 

(3)ServletRequestListener

用于监听每一次请求 的开始【初始化】 与结束【销毁】

技术图片
package cn.cen2guo.clinic.listener;

import javax.servlet.ServletRequestEvent;
import javax.servlet.ServletRequestListener;



/**
 * 用于监听每一次请求,
 */
//使用注解@WebListener 和 @Component ,则不需要去web.xml文件里注册监听 ,
//同时spring扫面也不需要特意设定可以扫描到这里 ,但是仍然可以识别,这就很舒服了
//@WebListener
//@Component
public class MyServletRequestListener implements ServletRequestListener {

    @Override
    public void requestInitialized(ServletRequestEvent sre) {
//        System.out.println("requestInitialized 初始化");
    }


    @Override
    public void requestDestroyed(ServletRequestEvent sre) {
//        System.out.println("requestDestroyed 销毁");
    }
    
}
MyServletRequestListener

 

 

 

3.  注册监听有两种,任意一种都可以:

  方法一:使用spring注解 

技术图片

 

 

   

  方法二 : 去web.xml文件注册监听标签

技术图片

 

 

 

 

4.心得 

 (1) 服务器开启,servletcontextListener首先被使用。servletcontext被创建了;

服务器关闭的前一刻才会触发其销毁监听内容

(2)  网页向controller请求,ServletRequestListener 首先检测出来,
执行了他的requestInitialized 方法,即初始化request;等待contronller事务结束后,才出发servletRequestListener的销毁事件

(3)并不是每次前端向服务器请求 都会 验证要不要创建Session  ,而是当服务器调用了HttpServletRequest.getSession(true) 后,

才会创建一个服务器内独一无二的session会话  ,其session id 则是自动分配一个无序的字符串,[得到两个一样的几率非常低]

然后才保存在前端[一般在cookie里面]。

(4)session 可以设置存活时间,到期后自动注销 ,但往往都是默认值,每当前端浏览器关闭后,session才开始以默认期限倒计时,

等待时间到后才销毁,并不是浏览器一关闭,就会销立马销毁 ,当然,也没必要手动对其销毁,让其自毁自灭就行,

根据这一特性,就无法让服务器判断前端用户是否仍在,想要实现这个功能,只能使用websocket 或者长轮询,长轮询太消耗资源了,不建议使用,

websocket则是最好的方式!!!

(5) 从Tomcat设置的cookie路径来看,它对不同的应用程序设置的cookie路径是不同的,这样不同的应用程序所用的session id是不同的,因此即使在

同一个浏览器窗口里访问不同的应用程序,发送给服务器的session id也可以是不同的。

 

以上是关于tomcat 服务器的几个重要监听 方法 与 使用的主要内容,如果未能解决你的问题,请参考以下文章

本地主机上的tomcat v7.0服务器所需的几个端口(8080,8009)已在使用[重复]

Android Adapter的几个方法

hadoop集群中的几个重要概念

tomcat调优的几个方面(转)

Tomcat 服务器在 localhost 所需的几个端口(8005、8080、8009)已在使用中

Web Service中的几个重要术语