strtuts2 ajax session失效处理

前端之家收集整理的这篇文章主要介绍了strtuts2 ajax session失效处理前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在Struts应用中,我们发出的请求都会经过 相应的拦截器进行相关处理,一般都会有一个用户登录拦截(Session失效拦截);一般请求的话,如果Session失效时,我们会跳到登录页面,可是如果我们采用AJAX请求时,将会返回登录页面HTML代码,这肯定不是我们想要的,那么我们如何解决呢?请看以下步骤:

一、建立拦截

Java代码

收藏代码

  1. packagecom.xxx.planeap.interceptor;

  2. importjavax.servlet.http.HttpServletRequest;

  3. importjavax.servlet.http.HttpServletResponse;

  4. importorg.apache.log4j.Logger;

  5. importorg.apache.struts2.ServletActionContext;

  6. importcom.opensymphony.xwork2.ActionContext;

  7. importcom.opensymphony.xwork2.ActionInvocation;

  8. importcom.opensymphony.xwork2.ActionSupport;

  9. importcom.opensymphony.xwork2.interceptor.AbstractInterceptor;

  10. importcom.xxx.common.contants.ConstantsKey;

  11. importcom.xxx.common.contants.SessionKey;

  12. importcom.xxx.planeap.domain.User;

  13. importcom.xxx.planeap.security.SecurityContextUtil;

  14. /**

  15. *

  16. *@authorGomaOMA1989@YEAH.NET

  17. *@versionv1.0

  18. *@since2012-05-31

  19. *

  20. */

  21. publicclassSecurityInterceptorextendsAbstractInterceptor{

  22. privatestaticfinallongserialVersionUID=1L;

  23. privateLoggerlogger=Logger.getLogger(SecurityInterceptor.class);

  24. @Override

  25. publicStringintercept(ActionInvocationinvocation)throwsException{

  26. //TODOAuto-generatedmethodstub

  27. StringclassName=invocation.getAction().getClass().getName();

  28. Stringaction=className.substring(className.lastIndexOf(".")+1,className.length());

  29. StringactionName=invocation.getProxy().getActionName();

  30. Stringresult;

  31. HttpServletRequestrequest=ServletActionContext.getRequest();

  32. HttpServletResponseresponse=ServletActionContext.getResponse();

  33. Stringtype=request.getHeader("X-Requested-With");

  34. Useruser=(User)ActionContext.getContext().getSession().get(SessionKey.CURRENT_USER);

  35. if(user==null){

  36. logger.debug("SECURITYCHECKED:NEEDTOLOGIN");

  37. if("XMLHttpRequest".equalsIgnoreCase(type)){//AJAXREQUESTPROCESS

  38. response.setHeader("sessionstatus",ConstantsKey.MSG_TIME_OUT);

  39. result=null;

  40. }else{//NORMALREQUESTPROCESS

  41. result=ActionSupport.LOGIN;

  42. }

  43. }else{

  44. logger.debug("SECURITYCHECKED:USERHASLOGINED");

  45. SecurityContextUtil.setCurrentUser(user);

  46. booleanhanPerm=SecurityContextUtil.hasPerm(action,actionName);

  47. logger.debug("SECURITYCHECKED:PERMISSION---"+action+"."+actionName+"="+hanPerm);

  48. result=invocation.invoke();

  49. }

  50. returnresult;

  51. }

  52. }

二、定义全局AJAX请求结束处理方法

Js代码

收藏代码

  1. //全局的AJAX访问,处理AJAX清求时SESSION超时

  2. $.ajaxSetup({

  3. contentType:"application/x-www-form-urlencoded;charset=utf-8",

  4. complete:function(XMLHttpRequest,textStatus){

  5. //通过XMLHttpRequest取得响应头,sessionstatus

  6. varsessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus");

  7. if(sessionstatus=="timeout"){

  8. //这里怎么处理在你,这里跳转登录页面

  9. window.location.replace(PlanEap.getActionURI("login"));

  10. }

  11. }

  12. });

原文链接:https://www.f2er.com/ajax/160915.html

猜你在找的Ajax相关文章