一、引言
上一篇文章学习了java三大器的拦截器,拦截器主要是针对于action请求进行拦截处理的,那么对于requst的一些信息如果在调用前,想先进行过滤和处理,那么就要使用到第二个神器,也就是本文的主角过滤器~那首先先简单了解一下过滤器的基本原理。
概念:拦截request进行处理后再交给下一个过滤器或servlet处理的中间组件,也可以对返回的response进行拦截处理。
作用域:在服务器启动时就会创建的,只会创建一个实例,常驻内存。
应用场景:统一设置编码格式、访问权限控制、敏感字符过滤、自动登录等。
下面通过代码来看下过滤器的几个应用场景~
二、代码实现
实现过滤器功能,我们得先进行一些前期的配置:
按照上图配置好了以后,重启SpringBoot项目时,我们自定义的过滤器就能生效了
字符编码过滤器
/**
* 字符编码过滤器
* @Author 有梦想的肥宅
*/
@WebFilter(
urlPatterns = "/*",/*通配符(*)表示对所有的web资源进行拦截*/
initParams = {
@WebInitParam(name = "filterName", value = "CharsetFilter"),
@WebInitParam(name = "charset", value = "utf-8")
})
@Order(1)//指定过滤器的执行顺序,值越大越靠后执行
public class CharsetFilter implements Filter {
private String filterName;
private String charset;
/**
* 初始化方法 接收一个FilterConfig类型的参数 该参数是对Filter的一些配置
*/
@Override
public void init(FilterConfig config) throws ServletException {
filterName = config.getInitParameter("filterName");
charset = config.getInitParameter("charset");
System.out.println("过滤器名称:" + filterName);
System.out.println("字符集编码:" + charset);
}
/**
* 过滤方法 主要是对request和response进行一些处理,然后交给下一个过滤器或Servlet处理
*/
@Override
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
System.out.println(filterName + "doFilter()");
req.setCharacterEncoding(charset);//设置请求request的字符编码
resp.setCharacterEncoding(charset);//设置响应response的字符编码
chain.doFilter(req, resp);
}
/**
* 销毁时方法
*/
@Override
public void destroy() {
System.out.println(filterName + "销毁");
}
}
源码贴上了,来简单解析一下:
我们常用的过滤器配置有一下几种:
urlPatterns:配置要拦截的资源
- 1、以指定资源匹配。例如"/login.html"
- 2、以目录匹配。例如"/user/login/*"
- 3、以后缀名匹配,例如"*.html"
- 4、通配符,拦截所有web资源。"/*"
initParams:配置初始化参数
- 使用@WebInitParam注解来配置,如:@WebInitParam(name = "charset", value = "utf-8")