概述
过滤器对象,可以对资源(Servlet 或静态资源)的请求或响应执行过滤操作。过滤器在 doFilter 方法中执行过滤。每个过滤器都可以访问一个 FilterConfig 对象,从中获取初始化参数,一个对 ServletContext 的引用,它可以使用这个引用来加载过滤任务所需的资源。
注意/*当访问服务器的资源时,过滤器可以将请求拦截下来,并根据条件完成一些过滤的操作。*/
作用
过滤器用于完成一些通用的操作【封装】
- 登录验证
- 编码集处理
- 敏感字符过滤【代理】
- 日志和审核
- 数据转换和压缩
- 加密
常用 API
// 过滤器接口,内置三个抽象方法
interface Filter {
// 初始化方法
void init(FilterConfig var1);
// 【重点】核心方法,过滤器的入口,用来处理过滤逻辑,可通过过滤器链对象的doFilter方法进行放行
void doFilter(ServletRequest var1, ServletResponse var2, FilterChain var3);
// 销毁方法
void destroy();
}
// 过滤器配置对象,在初始化期间将信息传递给过滤器
interface FilterConfig {
String getFilterName();
ServletContext getServletContext();
String getInitParameter(String var1);
}
// 【重点】过滤器链对象,用来调用下一个过滤器或者访问资源
interface FilterChain {
void doFilter(ServletRequest var1, ServletResponse var2);
}
!!!注意:每次由于浏览器请求链末端的资源而通过链传递请求/响应对象时,容器都会调用过滤器的 doFilter 方法。传入此方法的过滤器链允许过滤器将请求和响应传递给链中的下一个实体
步骤
-
声明一个类实现Filter接口(javax.servlet)
-
重写三个方法
-
声明@WebFilter注解,并添加访问路径:
/*
案例代码
// 声明过滤器注解
@WebFilter("/*")
public class FilterTest1 im