博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
通用的用户登录过滤器(SessionFilter)--【web.xml中配置】
阅读量:2352 次
发布时间:2019-05-10

本文共 4266 字,大约阅读时间需要 14 分钟。

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

 本系列文章导读:

        

        

        

        

        

功能描述

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

使用方法

        在 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
;
        
}
 
//         * 请求 时
//          * request.getRequestURL():
//         * 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() {
    
}
}
你可能感兴趣的文章
观察者模式
查看>>
中介者模式
查看>>
享元模式
查看>>
构造型模式
查看>>
生成器模式
查看>>
GitHub 删除代码库 详解
查看>>
Android Studio Rest Client工具详解
查看>>
IntelliJ IDEA 配置MySQL数据库 详解
查看>>
Android Studio 常用快捷键详解
查看>>
Cornerstone无法上传 .so 文件的问题
查看>>
Objective-C #pragma mark 详解
查看>>
Object-C 单例模式
查看>>
IOS 命名规范
查看>>
禁用sublime自动更新提示
查看>>
iOS Pch文件 详解
查看>>
Objective-C 获取控件 详解
查看>>
Objective-C 事件处理 详解
查看>>
IOS UIView 详解
查看>>
IOS 成员变量,属性变量,局部变量,实例变量,全局变量 详解
查看>>
Android ADB 详解
查看>>