import javax.servlet.*; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import java.io.IOException; /** * Created by Administrator on 2016/11/23. */ public class PermissionFilter implements Filter { private HttpServletRequest request; private HttpServletResponse response; @Override public void init(FilterConfig filterConfig) throws ServletException { } /*** * 请求服务时 * @param request * @param response * @param chain * @throws IOException * @throws ServletException */ @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { /** * httpRequest.getRequestDispatcher("/helloWorld").forward(httpRequest, response); 服务器端转发,不改变浏览器端URL地址,常用 httpResponse.sendRedirect(uri); 浏览器端重定向,改变URL在浏览器地址栏 */ /** * 1,doFilter的第一个参数为ServletRequest对象。此对象给过滤器提供了对进入的信息(包括 * 表单数据、cookie和HTTP请求头)的完全访问。第二个参数为ServletResponse,通常在简单的过 * 滤器中忽略此参数。最后一个参数为FilterChain,此参数用来调用servlet或JSP页。 */ this.request =(HttpServletRequest)request; /** * 如果处理HTTP请求,并且需要访问诸如getHeader或getCookies等在ServletRequest中 * 无法得到的方法,就要把此request对象构造成HttpServletRequest */ this.response = (HttpServletResponse) response; // 取得根目录所对应的绝对路径: String currentURL = this.request.getRequestURI(); // 截取到当前文件名用于比较 String targetURL = currentURL.substring(currentURL.indexOf("/", 1), currentURL.length()); HttpSession session = this.request.getSession(false); //拦截其他请求: // 用户权限不够是,重定向到提示权限不够接口 //不过滤登入的action 用户登录请求和提示用户登录请求直接过 if (!"/login".equals(targetURL)&&!"/nopermission".equals(targetURL)&&!"/nologin".equals(targetURL)) { // 用户未登录,跳转到提示接口 if (session == null || session.getAttribute(Constants.UserLogin.LOGINUSERMSG) == null) { this.request.getRequestDispatcher("/user/nologin").forward(request, response); return; } // 用户已登录,判断权限 else{ if("/permission".equals(targetURL)) { UserVO userVO = new UserVO(); userVO = (UserVO) session.getAttribute(Constants.UserLogin.LOGINUSERMSG); //权限不够,跳转到提示接口 if (userVO.getLevel()!=1){ this.request.getRequestDispatcher("/user/nopermission").forward(request, response); return; } } } } // 加入filter链继续向下执行 chain.doFilter(request, response); /** * 调用FilterChain对象的doFilter方法。Filter接口的doFilter方法取一个FilterChain对象作 为它 * 的一个参数。在调用此对象的doFilter方法时,激活下一个相关的过滤器。如果没有另 * 一个过滤器与servlet或JSP页面关联,则servlet或JSP页面被激活。 */ } /*** * 服务重启之后 */ @Override public void destroy() { this.request.getSession(false).setAttribute(Constants.UserLogin.LOGINUSERMSG,null); } }
web.xml
<filter> <filter-name>permissionFilter</filter-name> <filter-class>com.common.PermissionFilter</filter-class> </filter> <filter-mapping> <filter-name>permissionFilter</filter-name> <url-pattern>/*</url-pattern> <dispatcher>REQUEST</dispatcher> <!-- 没有配置dispatcher就是默认request方式的 --> <dispatcher>FORWARD</dispatcher> <dispatcher>ERROR</dispatcher> <dispatcher>INCLUDE</dispatcher> </filter-mapping>