servlet过滤器和监听器

过滤器

顾名思义是起到过滤的作用,所有的请求在真正到达servlet之前都会首先经过过滤器过滤一遍。过滤器也是Servlet的一种,因此也有init和destroy方法,还有一个服务方法,只是这里提供的服务是过滤;

一个Servlet要想成为过滤器需要实现javax.servlet.Filter接口;

一般客户端发出请求后会交给Servlet;如果过滤器存在,则客户端发出的请求都是先交给过滤器,然后交给Servlet

我们可以完成一些在执行Servlet之前必须要做的事,比如request.setCharacterEncoding("GBK");

必须实现以下方法:

1.public void init(FilterConfig config) throws ServletException{}   //   init方法在Web容器启动时就会调用;

2.public void doFilter(ServletRequest req,ServletResponse resp,FilterChain chain){}  // doFilter的参数是ServletRequestServletResponse而不是Http的;

3.public void destroy(){}//应用被关闭时调用

在实现doFilter方法时一定要执行如下操作:

public void doFilter(ServletRequest req,ServletResponse resp,FilterChain chain){

    chain.doFilter(req,resp);        //servlet传递请求,否则servlet无法执行

}

写完过滤器后,我们必须要限制过滤器调用的范围,即域名为多少时会调用过滤器,我们在web.xml 中进行配置

  1. <filter>  
  2.     <filter-name>myFilter</filter-name><!--filter的名字-->  
  3.     <filter-class>com.lq.Filter.Myfilter</filter-class><!--filter的类全路径-->  
  4. </filter>  
  5. <filter-mapping>  
  6.     <filter-name>myFilter</filter-name><!--和filter的名字一一对应-->  
  7.     <url-pattern>/*</url-pattern><!--比如url-pattern中为 /* ,则对于所有请求进行过滤-->             
  8. </filter-mapping> 

 

那么过滤器可以用来干嘛呢?大家可以做两个简单的案例:

案例1:统一设置字符集

案例2:拦截URL,不登录不允许直接访问页面

 

监听器

监听器顾名思义就是监听某种事件的发生,即当某个事件发生时,就触发了某个设置好的监听器,但是这里触发的原因不同。例如地震监测仪器监听地震的发生,大气监测仪,监测空气的变化以提供预警。

servlet中因监听对象的不同也分为不同的监听器,这里指的监听对象是applicationsession对象,每种对象有各自的监听器。

1.application监听器:ServletContextListener

需要实现的方法:

(1)public void contextInitialized(ServletContextEvent e);       //application创建时就调用

(2)public void contextDestroyed(ServletContextEvent e);        //application销毁时调用

ServletContextEventgetServletContext()方法可以取得application对象;

创建完成监听器后需要在web.xml中做如下配置

<listener>标签是单独出现的

包含一个子标签,指定了监听类的全称(包名+类名)

2.application属性监听器:ServletContextAttributeListener

需要实现的方法:

(1)public void attributeAdded(ServletContextAttributeEvent e);            //当调用application.setAttribute()时调用

(2)public void attributeRemoved(ServletContextAttributeEvent e);        //当调用applcaition.removeAttribute()时调用

(3)public void attributeReplaced(ServletContextAttributeEvent e);        //当调用两次application.setAttribute()赋予相同属性时调用

 

参数ServletContextAttributeEvent可以获得触发该监听器的属性名称和属性值,方法有:

(1)getName();  取得属性的名称;

(2)getValue();   取得属性的值;(注意:返回的是Object,必须转型)

3.session监听器:HttpSessionListener

需要实现的方法:

(1)public void sessionCreated(HttpSessionEvent e);                //当打开一个浏览器时,就会触发这个方法;

(2)public void sessionDestroyed(HttpSessionEvent e);            //当调用session.invalidate();或超时时调用

HttpSessionEvent的方法getSession()获得触发监听器的session对象;  

 

销毁session常用的有2种方式:

(1)session.invalidate();//直接销毁

(2)web.xml中设置超时时间://所有session起作用

 

  1. <session-config>  
  2.     <session-timeout>5</session-timeout>  <!-- 5分钟 -->  
  3. </session-config>  

注意:如果会话超时时间设置为-1,则表示会话永远不会超时;

4.session属性监听器:HttpSessionAttributeListener

需要实现的方法:

(1)public void attributeAdded(HttpSessionBindingEvent e);            //当调用session.setAttribute()时调用

(2)public void attributeRemoved(HttpSessionBindingEvent e);        //当调用session.removeAttribute()时调用

(3)public void attributeReplaced(HttpSessionBindingEvent e);         //当调用两次session.setAttribute()赋予相同属性时调用

HttpSessionBindingEvent 方法:

(1)getSession();//获取触发监听器的session

(2)getName();//获取属性名称

(3)getValue();//获取属性值

 

监听器应用场景

ServletContextListener:在任何Servlet提供服务之前执行、在Servlet销毁时执行,用于提前初始化一些资源,比如数据库连接、销毁一些资源,比如数据库连接;

ServletContextAttributeListener:上下文中添加、删除、替换了属性;

HttpSessionListener:多少个在线用户,即跟踪会话;

HttpSessionAttributeListener:会话属性添加、删除、替换;

 

综合案例:

做一个网站在线人数统计,可以通过ServletContextListener监听,当Web应用上下文启动时,在ServletContext中添加一个List.用来准备存放在线的用户名,然后通过HttpSessionAttributeListener监听,当用户登录成功,把用户名设置到Session中。同时将用户名放到ServletContext的List中,最后通过HttpSessionListener监听,当用户注销会话时,将用户名从应用上下文范围中的List列表中删除。

 



 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值