通用的用户登录过滤器(SessionFilter)--【web.xml中配置】

文章来源:http://www.cnblogs.com/hemingwang0902/archive/2012/01/09/session-filter.html   

 本系列文章导读:

        通用的用户登录过滤器(SessionFilter)

        设置不使用缓存的过滤器(ClearCacheFilter)

        设置站点黑名单的过滤器(BannedAccessFilter)

        将响应数据进行压缩处理的过滤器(CompressionFilter)

        替换禁用语(指定关键字)的过滤器(StopWordsFilter)

功能描述

        用于检查用户是否登录了系统,如果未登录,则重定向到指的登录页面。

使用方法

        在 java web 项目的 web.xml 文件中添加如下代码,对每个参数都进行了详细的说明。

<!—检查用户是否登录了系统的过滤器配置  开始 -->
< filter >
  < filter-name >SessionFilter</ filter-name >
  < filter-class >com.hmw.filter.SessionFilter</ filter-class >
  < init-param >
      < description >将当前登录的用户的信息保存在 session 中时使用的key,如果没有配置此参数,则该过滤器不起作用</ description >
      < param-name >sessionKey</ param-name >
      < param-value >userInfo</ param-value >
  </ init-param >
  < init-param >
      < description >
          如果用户未登录(即在 session 中 key 为 sessionKey 的属性不存在或为空),则将请求重定向到该 url。
          该 url 不包含web应用的 ContextPath。
          如果不配置此参数,则在用户未登录系统的情况下,直接重定向到web应用的根路径(/)
      </ description >
      < param-name >redirectUrl</ param-name >
      < param-value >/login.jsp</ param-value >
  </ init-param >
  < init-param >
      < description >
          不需要进行拦截的 url 的正则表达式,即:如果当前请求的 url 的 servletPath 能匹配该正则表达式,则直接放行(即使未登录系统)。
          此参数的值一般为 loginServlet 和 registServlet 等。
          另外,参数 redirectUrl 的值不用包含在该正则表达式中,因为 redirectUrl 对应的 url 会被自动放行。
          还有一点需要说明的是,该参数的值不包含web应用的 ContextPath。
      </ description >
      < param-name >excepUrlRegex</ param-name >
      <!-- 不拦截 /servlets/loginServlet 和 /servlets/registServlet -->
      < param-value >/servlets/(login|regist)Servlet</ param-value >
  </ init-param >
</ filter >
 
< filter-mapping >
  < filter-name >SessionFilter</ filter-name >
  < url-pattern >/servlets/*</ url-pattern >
</ filter-mapping >
< filter-mapping >
  < filter-name >SessionFilter</ filter-name >
  < url-pattern >/jsp/*</ url-pattern >
</ filter-mapping >
<!—检查用户是否登录了系统的过滤器配置  结束 -->

过滤器源码

package  com.hmw.filter;
 
import  java.io.IOException;
import  java.net.URLEncoder;
import  java.util.regex.Pattern;
 
import  javax.servlet.Filter;
import  javax.servlet.FilterChain;
import  javax.servlet.FilterConfig;
import  javax.servlet.ServletException;
import  javax.servlet.ServletRequest;
import  javax.servlet.ServletResponse;
import  javax.servlet.http.HttpServletRequest;
import  javax.servlet.http.HttpServletResponse;
 
import  org.apache.commons.lang.StringUtils;
 
/**
  * 用于检查用户是否登录了系统的过滤器<br>
  * 创建日期:2012-01-09
  * @author <a href="mailto:hemingwang0902@126.com">何明旺</a>
  */
public  class  SessionFilter implements  Filter {
 
     /** 要检查的 session 的名称 */
     private  String sessionKey;
     
     /** 需要排除(不拦截)的URL的正则表达式 */
     private  Pattern excepUrlPattern;
     
     /** 检查不通过时,转发的URL */
     private  String forwardUrl;
 
     @Override
     public  void  init(FilterConfig cfg) throws  ServletException {
         sessionKey = cfg.getInitParameter( "sessionKey" );
 
         String excepUrlRegex = cfg.getInitParameter( "excepUrlRegex" );
         if  (!StringUtils.isBlank(excepUrlRegex)) {
             excepUrlPattern = Pattern.compile(excepUrlRegex);
         }
 
         forwardUrl = cfg.getInitParameter( "forwardUrl" );
     }
 
     @Override
     public  void  doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws  IOException, ServletException {
         // 如果 sessionKey 为空,则直接放行
         if  (StringUtils.isBlank(sessionKey)) {
             chain.doFilter(req, res);
             return ;
         }
 
//         * 请求 http://127.0.0.1:8080/webApp/home.jsp?&a=1&b=2
//          * request.getRequestURL(): http://127.0.0.1:8080/webApp/home.jsp
//         * request.getContextPath(): /webApp
//         * request.getServletPath():/home.jsp
//         * request.getRequestURI(): /webApp/home.jsp
//         * request.getQueryString():a=1&b=2
         HttpServletRequest request = (HttpServletRequest) req;
         HttpServletResponse response = (HttpServletResponse) res;
         String servletPath = request.getServletPath();
 
         // 如果请求的路径与forwardUrl相同,或请求的路径是排除的URL时,则直接放行
         if  (servletPath.equals(forwardUrl) || excepUrlPattern.matcher(servletPath).matches()) {
             chain.doFilter(req, res);
             return ;
         }
 
         Object sessionObj = request.getSession().getAttribute(sessionKey);
         // 如果Session为空,则跳转到指定页面
         if  (sessionObj == null ) {
             String contextPath = request.getContextPath();
             String redirect = servletPath + "?"  + StringUtils.defaultString(request.getQueryString());
             /*
              * login.jsp 的 <form> 表单中新增一个隐藏表单域:
              * <input type="hidden" name="redirect" value="${param.redirect }">
              *
              *  LoginServlet.java 的 service 的方法中新增如下代码:
              *  String redirect = request.getParamter("redirect");
              *  if(loginSuccess){
              *      if(redirect == null || redirect.length() == 0){
              *          // 跳转到项目主页(home.jsp)
              *      }else{
              *          // 跳转到登录前访问的页面(java.net.URLDecoder.decode(s, "UTF-8"))
              *      }
              *  }
              */
             response.sendRedirect(contextPath + StringUtils.defaultIfEmpty(forwardUrl, "/" )
                             + "?redirect="  + URLEncoder.encode(redirect, "UTF-8" ));
         } else  {
             chain.doFilter(req, res);
         }
     }
 
     @Override
     public  void  destroy() {
     }
}
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值