在struts2中使用拦截器(Interceptor)控制登录和权限

在jsp servlet中我们通常使用Servlet Filter控制用户是否登入, 是否有权限转到某个页面。在struts2中我们应该会想到他的拦截器(Interceptor), Interceptor在struts2中起着非常重要的作用。 很多struts2中的功能都是使用Interceptor实现的。 

需求:简单的登入界面,让用户输入用户名、密码、记住密码(remember me)。 如果用户选中remember me的话, 下次就不需要再登入了(使用cookie实现, 用需要点击logout取消remeber me功能)。 如果用户起始输入的地址不是登入页面的话,在用户登入之后需要转到用户输入的起始地址。 

我们先看看LoginInterceptor.java 
Java代码   收藏代码
  1. package com.javaeye.dengyin2000.wallet.interceptor;  
  2.   
  3. import java.util.Map;  
  4.   
  5. import javax.servlet.http.Cookie;  
  6. import javax.servlet.http.HttpServletRequest;  
  7.   
  8. import org.apache.commons.lang.StringUtils;  
  9. import org.apache.struts2.StrutsStatics;  
  10.   
  11. import com.javaeye.dengyin2000.wallet.dao.UserDAO;  
  12. import com.javaeye.dengyin2000.wallet.dao.UserNotFoundException;  
  13. import com.javaeye.dengyin2000.wallet.domains.User;  
  14. import com.opensymphony.xwork2.ActionContext;  
  15. import com.opensymphony.xwork2.ActionInvocation;  
  16. import com.opensymphony.xwork2.interceptor.AbstractInterceptor;  
  17.   
  18. public class LoginInterceptor extends AbstractInterceptor {  
  19.     public static final String USER_SESSION_KEY="wallet.session.user";  
  20.     public static final String COOKIE_REMEMBERME_KEY="wallet.cookie.rememberme";  
  21.     public static final String GOING_TO_URL_KEY="GOING_TO";  
  22.       
  23.     private UserDAO userDao;  
  24.   
  25.     @Override  
  26.     public String intercept(ActionInvocation invocation) throws Exception {  
  27.           
  28.         ActionContext actionContext = invocation.getInvocationContext();  
  29.         HttpServletRequest request= (HttpServletRequest) actionContext.get(StrutsStatics.HTTP_REQUEST);  
  30.           
  31.         Map session = actionContext.getSession();  
  32.         if (session != null && session.get(USER_SESSION_KEY) != null){  
  33.             return invocation.invoke();  
  34.         }  
  35.           
  36.         Cookie[] cookies = request.getCookies();  
  37.         if (cookies!=null) {  
  38.             for (Cookie cookie : cookies) {  
  39.                 if (COOKIE_REMEMBERME_KEY.equals(cookie.getName())) {  
  40.                     String value = cookie.getValue();  
  41.                     if (StringUtils.isNotBlank(value)) {  
  42.                         String[] split = value.split("==");  
  43.                         String userName = split[0];  
  44.                         String password = split[1];  
  45.                         try {  
  46.                             User user = userDao  
  47.                                     .attemptLogin(userName, password);  
  48.                             session.put(USER_SESSION_KEY, user);  
  49.                         } catch (UserNotFoundException e) {  
  50.                             setGoingToURL(session, invocation);  
  51.                             return "login";  
  52.                         }  
  53.                     } else {  
  54.                         setGoingToURL(session, invocation);  
  55.                         return "login";  
  56.                     }  
  57.                     return invocation.invoke();  
  58.                 }  
  59.             }  
  60.         }  
  61.         setGoingToURL(session, invocation);  
  62.         return "login";  
  63.     }  
  64.   
  65.     private void setGoingToURL(Map session, ActionInvocation invocation){  
  66.         String url = "";  
  67.         String namespace = invocation.getProxy().getNamespace();  
  68.         if (StringUtils.isNotBlank(namespace) && !namespace.equals("/")){  
  69.             url = url + namespace;  
  70.         }  
  71.         String actionName = invocation.getProxy().getActionName();  
  72.         if (StringUtils.isNotBlank(actionName)){  
  73.             url = url + "/" + actionName + ".action";  
  74.         }  
  75.         session.put(GOING_TO_URL_KEY, url);  
  76.     }  
  77.       
  78.     public UserDAO getUserDao() {  
  79.         return userDao;  
  80.     }  
  81.   
  82.     public void setUserDao(UserDAO userDao) {  
  83.         this.userDao = userDao;  
  84.     }  
  85.   
  86. }  


首先判断session中有没有用户信息, 如果有的话继续, 如果没有的话,检查cookie中有没有rememberme的值,如果有的话,用==分割, 取得用户名密码进行登入。如果没有这个用户的话,记录下request的action地址然后转到登入页面。如果验证有这个用户,则继续下面的interceptor。 如果cookie中没有信息的话,则记录request的action地址然后转到登入页面。  以上就是LoginInterceptor的全部代码。 

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值