Listener&Filter

Servlet中的Listener简介

用于监听的事件源分别是ServletContext, HttpSession和ServletRequest这三个域对象.

使用方法

1.创建一个类,实现相应的监听器接口
2.配置WEB-INF里的web.xml文件,添加配置如下:


  类的全路径 

Servlet中的Listener分类

  • 用于监听三个域对象的创建和销毁的监听器(三个)

1.ServletContextListener监听器
2.HttpSessionListener监听器
3.ServletRequestListener监听器

  • 监听三个域对象的属性变更(属性添加、移除、替换)的监听器(三个)

1.ServletContextAttributeListener
2.HttpSessionAttributeListener
3.ServletRequestAttributeListener

  • 监听HttpSession中JavaBean的状态改变(钝化、活化、绑定、解除绑定)的监听(两个)

1.HttpSessionBindingListener
监听Java类在HttpSession中的绑定和解除绑定的状态的监听器
2,HttpSessionActivationListener
监听HttpSession中Java类的钝化和活化监听器

  • 实现这两个接口的类不需要在web.xml中进行配置
  • 配置完成session的序列化和反序列化
    Context标签可以配置在:
    tomcat/conf/context.xml:所有tomcat下虚拟主机和虚拟目录下的工程都会序列化session
    tomcat/conf/Catalina/localhost/context.xml:localhost虚拟主机下的所有项目会序列化session
    工程/META-INF/context.xml:当前工程才会序列化session。

    
      
    

Filter使用方法

1.编写一个类实现Filter接口
2.对过滤器进行配置


  访问名
  全路径


  访问名
  拦截位置

  • 的配置
    1.完全路径匹配:以/开始 比如/aaa /aaa/bbb
    2.目录匹配:以/开始 以*结束 比如/* , /aaa/*, /aaa/bbb/*
    3.扩展名匹配:不能以/开始 以*开始 比如*.jsp, *.do, *.action
  • 的配置
    标签中写入标签,用以拦截指定的Servlet.
  • 的配置
    默认的情况下过滤器会拦截请求。如果进行转发(需要拦截这次转发)。
    dispatcher的取值:
    1.REQUEST:默认值。默认过滤器拦截的就是请求。
    2.FORWARD:转发。
    3.INCLUDE:页面包含的时候进行拦截
    4.ERROR:页面出现全局错误页面跳转的时候进行拦截

FilterChain对象的概述

FilterChain过滤器链:在一个web应用中,可以开发编写多个Filter,这些Filter组合起来称为是一个过滤器链。
Web服务器根据Filter在web.xml文件中的注册顺序(mapping的配置顺序)决定先调用那个Filter。依次调用后面的过滤器,如果没有下一个过滤器,调用目标资源

你可能感兴趣的:(Listener&Filter)