过滤器
问题:设置解码字符集时,以下的代码出现在了多处servlet中,
要求:希望避免出现重复代码
request.setCharacterEncoding(“utf-8”);
1. 概念
Filter 过滤器
可以对请求(响应)进行过滤
请求 --> 过滤器1 --> 过滤器2 --> … --> 过滤器n --> 目的地(Servlet, jsp)
2. 编写过滤器的步骤
- 实现Filter接口
- 在类上添加@WebFilter(urlPattern=“要过滤的目标路径”)
- 在doFilter方法中控制请求是否前进到下一个过滤器
filterChain.doFilter(request, response); // 调用此方法,表示请求继续前进,不调用,请求就停止不前了
3. 匹配路径的三种写法
-
精确匹配:目标路径是过滤器路径就是什么
例如: /s1 /s2 … -
前缀匹配:
例如:有两个servlet,路径分别是 /user/s1, /user/s2
过滤器的匹配路径就可以写为: /user/ *
/ * 表示匹配此应用程序中所有路径 -
后缀匹配:
*.后缀
注意: 后缀匹配不要以/开头, 精确匹配和前缀匹配需要以/开头
*.jsp 表示在请求到达所有jsp之前,经过此过滤器
4. 多个过滤器
使用@WebFilter去控制匹配路径时,多个过滤器都匹配目标,执行顺序和过滤器类名有关。
按类名的字母顺序排序
5. 过滤器的应用
应用1: 字符编码过滤器
在过滤器中统一调用 request.setCharacterEncoding方法
应用2: 登录检查
HttpServletRequest request = (HttpServletRequest) servletRequest;
HttpSession session = request.getSession();
// 检查是否有登录标记
if(session.getAttribute("isLogin") == null) { // 如果没有找到
request.getRequestDispatcher("/login.jsp").forward(request, servletResponse);
return;
} else { // 找到登录标记, 放行请求,让请求继续前进
filterChain.doFilter(request, servletResponse);
}