JavaWeb开发06——监听器和过滤器

过滤器和监听器


一.过滤器
1.概述

过滤器运行在服务器端,对服务器端web资源的访问 进行拦截,起到过滤的作用。Servlet API中 定义接口 Filter,用户只需要编写程序实现Filter接口,完成过滤器编写。

语法格式:
1、编写类 实现 Filter接口
2、在服务器端注册 Filter (配置拦截哪个web资源) ----- web.xml 
  
  
      Filter1
      cn.itcast.filter.Filter1
      
  
  
      Filter1
      /hello.jsp
      

3、客户端访问被拦截目标资源之前,服务器调用Filter的doFilter方法 ,执行过滤
4、Filter的doFilter方法中传入 FilterChain, 如果调用FilterChain的doFilter 就会执行目标资源,否则目标资源不会执行 
chain.doFilter(request, response);

例子:
public class Demo1Filter implements Filter {
     public void destroy() {
        System.out.println("Demo1Filter销毁了.....");
    }

     public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain) throws IOException, ServletException {
        System.out.println("demo1filter 前");
        chain.doFilter(request, response);
        System.out.println("demo1filter 后");
    }
}

web.xml:

        Demo1Filter
        com.itheima.filter.Demo1Filter
        
            name1
            value1
        
        
            name2
            value2
        
        
            name3
            value3
        

    

        Demo1Filter
        /*
        REQUEST
        FORWARD
2.过滤器设置

1)FilterChain:
在客户端访问服务器web资源时,服务器端为一个web资源,配置多个过滤器拦截 ,这多个过滤器,就会组成过滤器链 FilterChain, 调用FilterChain的doFilter 表示要执行过滤器链下一个资源,如果当前过滤器已经是链上最后一个过滤器,就会执行目标资源

Tip:

web服务器根据Filter在web.xml文件中的注册顺序,决定先调用哪个Filter

2)
过滤器拦截配置
1、如果连接目标资源是一个Servlet,可以选择url和servlet名称两种配置方式

/hello

HelloServlet

3)url-pattern:
url-pattern和 Servlet中路径写法一样,有三种 : 完全匹配、目录匹配、扩展名匹配

4)
指定过滤器所拦截的资源被 Servlet 容器调用的方式
容器调用服务器端资源 有四种方式
REQUEST、FORWARD、INCLUDE、ERROR

二.监听器
1.概述

监听器就是一个java程序,功能是监听另一个java对象变化(方法调用、属性变更)

public class MyHSesssionListener implements HttpSessionListener {

    public void sessionCreated(HttpSessionEvent se) {
        System.out.println("session对象被创建出来了..."+se.getSession());
    }

    public void sessionDestroyed(HttpSessionEvent se) {
        System.out.println("session对象被销毁了..."+se.getSession());
    }

}
2.三种监听器

1.用来监听三大作用域的创建和销毁的监听器

1)ServletContextListener 用来监听ServletContext对象创建和销毁的监听器
创建:服务器启动,web应用加载后立即创建代表当前web应用的ServletContext对象
销毁:服务器关闭或web应用被移除出容器时,随着web应用的销毁而销毁

2)HttpSessionListener 用来监听HttpSession对象创建和销毁的监听器
创建:第一次调用request.getSession方法时创建代表当前会话的session对象
销毁:超过30分钟没人用销毁/调用invalidate方法自杀/服务器非正常关闭时随着web应用的销毁而销毁,如果服务器是正常关闭会被钝化起来.

Tips:
当服务器正常关闭时,还存活着的session会随着服务器的关闭被以文件的形式存储在tomcat的work目录下,这个过程叫做session的钝化。
当服务器再次正常开启时,服务器会找到之前的SESSIONS.ser文件从中恢复之前保存起来的session对象这个过程叫做session的活化。
想要随着Session被钝化活化的对象它的类必须实现Serializable接口。

3)ServletRequestListener 用来监听ServletRequest对象创建和销毁的监听
创建:请求开始创建代表请求的request对象
销毁:请求结束时代表请求的request对象销毁

2.用来监听三大作用域中属性变化的监听器
ServletContextAttributeListener
HttpSessionAttributeListener
ServletRequestAttributeListener

3.使javabean自己感知自己在Session中状态变化的监听器,这两个监听器很特殊,不需要自己去写类实现也不需要在web.xml中注册,只要使javabean实现这个接口就能起作用

1)HttpSessionBindingListener
javabean被绑定到session中
sessionDidActive(HttpSessionBindingEvent event)

javabean被移除绑定从session中
valueUnbound(HttpSessionBindingEvent event)方法

2)HttpSessionActivationListener
javabean随着session被钝化
sessionWillPassivate(HttpSessionBindingEvent event)

javabean随着session被活化
sessionDidActive(HttpSessionBindingEvent event)

你可能感兴趣的:(java后端java-web)