Filter:过滤器
当访问服务器的资源时候,过滤器可以将请求拦截下来,完成一些特殊的功能
如:登录验证,统一编码,敏感字符
快速入门
- 定义一个类,实现接口Filter
- 复写方法
- 配置拦截路径
- @WebFilter("/*")
- 在doFilter方法里设置放行
filterChain.doFilter(servletRequest,servletResponse)
细节:
1.过滤器web.xml配置:和配置Servlet差不多,但是Filter是设置拦截路径,使用的是<filter>
2.过滤器执行流程:
对request的请求消息增强、放行、对response的响应消息增强
执行过滤器,执行放行的资源,回来执行过滤器放行代码下边的代码
3.生命周期:
init() 在服务器启动后,会创建filter对象,然后调用init方法
doFilter() 多次执行,每一次请求被拦截的时候,就会执行
destroy() 在服务器关闭后,Filter对象被销毁,正常关闭服务器就会执行这个方法
4.过滤器配置详解:
- 具体路径:/index.jsp ,只有访问index.jsp资源时,过滤器才会执行
- 拦截目录:/user/* 访问/user下的所有资源时,过滤器才会执行
- 后缀拦截: *.jsp 访问后缀为jsp的文件,过滤器才会执行
- 拦截所有:/* 访问所有资源都会被拦截
拦截方式配置:资源访问的方式
注解配置:设置dispatcherTypes属性
5.过滤器链:
- 过滤器1
- 过滤器2
- 放行
- 过滤器2
- 过滤器1
注解配置,会自动比较A B 类名
web.xml配置,谁前谁就先执行
Listener监听器
- 事件:一件事件
- 事件源:事件发生的地方
- 监听器:一个对象
- 注册监听:将事件 事件源 监听器绑定一起,当事件源发生某个事件,执行监听器代码
ServletContextListener:监听ServletContext对象的创建和销毁
void contextDestroyed(SerletContextEvent sce):ServletContext对象被销毁之前会调用该方法
void contextInitialized(SerletContextEvent sce):ServletContext对象创建后会调用该方法
步骤:
- 定义一个类,实现ServletContextListener接口
- 复写方法
- 配置:web.xml
<Listener>
和 注解