作用:过滤任意的请求和响应
使用
1. 编写一个过滤器类:
实现Filter接口,必须重写doFilter方法,可选 重写init、destory方法
2. web.xml中配置过滤器(推荐):
<filter>
<filter-name></filter-name>
<filter-class>org.class.jgs1904.filter.LifeFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>LifeFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
注意:多个过滤器会根据配置的次序依次执行
3. web3.0之后也可以使用注解进行配置
@WebFilter("/*")
注意:安装类的顺序(名称的字典顺序)依次执行
@WebFilter("/*")
public class LifeFilter implements Filter {
/**
* 执行过滤
* 时机:每次请求和响应
* 次数:每次请求和响应方法完整执行一次
*/
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
System.out.println("LifeFilter执行过滤...");
// 放行请求
chain.doFilter(request, response);
System.out.println("LifeFilter执行过滤完毕...");
}
/**
* 初始化
* 时机:项目启动加载到过滤器配置时
* 次数:一次
*/
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("LifeFilter初始化...");
}
/**
* 销毁
* 时机:服务器正常关闭时
* 次数:一次
*/
@Override
public void destroy() {
System.out.println("LifeFilter销毁...");
}
}
生命周期
1. init:时机:项目启动加载到过滤器配置时;次数:一次
2. doFilter:时机:每次请求和响应;次数:每次请求和响应
3. destory:时机:服务器正常关闭时;次数:一次
实例:
- 统一解决请求和响应的乱码
public class EncodingFilter implements Filter{
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
// 解决请求乱码
request.setCharacterEncoding("utf-8");
// 解决响应乱码
response.setContentType("text/html; charset=UTF-8");
chain.doFilter(request, response);
}
}
- 判断用户有没有登陆,如果没登陆,重定向到登陆页面
public class LoginFilter implements Filter {
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
// 获取过滤的url地址
String requestUrl = httpRequest.getRequestURL().toString();
// 如果包含不拦截的页面,直接放行
if (requestUrl.endsWith("/login.jsp") || requestUrl.endsWith("/regist.jsp") || requestUrl.endsWith(httpRequest.getContextPath() + "/")) {
chain.doFilter(request, response);
return;
}
// 如果包含不拦截的method,直接放行
String method = httpRequest.getParameter("method");
if ("login".equals(method) || "regist".equals(method) || "get".equals(method)) {
chain.doFilter(request, response);
return;
}
// 如果包含不拦截的路径,直接放行
if (requestUrl.contains("/static")) {
chain.doFilter(request, response);
return;
}
// 从session中获取在线用户
User onlineUser = (User)httpRequest.getSession().getAttribute("onlineUser");
// 判断在线用户是否为空
if (onlineUser == null) {
System.out.println("拦截请求:" + requestUrl);
httpResponse.sendRedirect(httpRequest.getContextPath() + "/user/login.jsp");
return;
}
// 有在线用户直接放行
chain.doFilter(request, response);
}
}