Servlet中的Listener简介
用于监听的事件源分别是ServletContext, HttpSession和ServletRequest这三个域对象.
使用方法
1.创建一个类,实现相应的监听器接口
2.配置WEB-INF里的web.xml文件,添加配置如下:
<listener>
<listener-class>类的全路径 <listener-class>
</listener>
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。
<Context>
<Manager className="org.apache.catalina.session.PersistentManager" maxIdleSwap="1">
<Store className="org.apache.catalina.session.FileStore" directory="itheima"/>
</Manager>
</Context>
Filter使用方法
1.编写一个类实现Filter接口
2.对过滤器进行配置
<filter>
<filter-name>访问名</filter-name>
<filter-class>全路径</filter-class>
</filter>
<filter-mapping>
<filter-name>访问名</filter-name>
<url-pattern>拦截位置</url-pattern>
</filter-mapping>
- <url-pattern>的配置
1.完全路径匹配:以/开始 比如/aaa /aaa/bbb
2.目录匹配:以/开始 以*结束 比如/* , /aaa/*, /aaa/bbb/*
3.扩展名匹配:不能以/开始 以*开始 比如*.jsp, *.do, *.action
- <servlet-name>的配置
在<filter-mapping>标签中写入<servlet-name>标签,用以拦截指定的Servlet. - <dispatcher>的配置
默认的情况下过滤器会拦截请求。如果进行转发(需要拦截这次转发)。
dispatcher的取值:
1.REQUEST:默认值。默认过滤器拦截的就是请求。
2.FORWARD:转发。
3.INCLUDE:页面包含的时候进行拦截
4.ERROR:页面出现全局错误页面跳转的时候进行拦截
FilterChain对象的概述
FilterChain过滤器链:在一个web应用中,可以开发编写多个Filter,这些Filter组合起来称为是一个过滤器链。
Web服务器根据Filter在web.xml文件中的注册顺序(mapping的配置顺序)决定先调用那个Filter。依次调用后面的过滤器,如果没有下一个过滤器,调用目标资源