日期:2014-05-16  浏览次数:20711 次

Ajax请求Session超时时重定向解决方案
我使用的Struts2.3.4,配置的LoginInterceptr拦截器,所有请求除了登录请求外都会先经过拦截器,在拦截器里获取Session信息,判断用户信息是否存在,因为如果Session超时,Session中的信息是会被清除掉的。

所以如果Session已超时,对于非Ajax请求,会直接重定向到登录页面,但是对于Ajax请求则不会,这里给出解决方案,经过测试,绝对可行!当然,如果谁有更好的方法请贴出来:

如果想要Ajax请求在当Session超时的时候也重定向,则需要服务端返回错误信息,在ajax回调函数中做判断,看了看Jquery文档,说是可以定义全局函数,但是不知道那玩意怎么用,试了半天都没试出来!所以只得用如下方法来发Ajax请求:
	function show_userList(){
		$.ajax({
			type: "GET",
  			url: "ms/user!userList.action?dd="+new Date().getTime(),
			success: function(msg){
				     $("#bd").html(msg);
					},
			complete:function(XMLHttpRequest,textStatus){ 
                 if(textStatus=="error"){
                  	var ll = "<%=basePath%>";
                  	alert("basePath : "+ll);
                    window.location=ll+"/login"; 
                 } 
             }
		});
	}


Jquery文档中如是说:complete 当请求完成之后调用这个函数,无论成功或失败。幸好有这么个可爱的回调函数!! 而$.get()、$.load()、$.post()方式的回调函数都是调用成功返回才会触发的回调函数,所以只能使用如上这种方式!

原理如下:
发送Ajax请求,无论成功或失败,都会调用complete回调函数,所以如果Sessio超时了,complete回调函数中的textStatus的值为===>>请注意红色部分error,值为error,则可以判断如果为error则使用window.location="你的登录首页"这种方式重定向浏览器。


就这么简单,根本不用什么在服务端写入HttpHeader任何信息,服务端不需要做任何处理,所需要做的仅仅是如上我给出的代码一样,再申明一次,绝对正确,我使用的jquery是1.7.2版本!其它版本没测试过!

如有疑问或者是更好的方式欢迎交流!

更正一点
由于缓存原因给我造成了错觉,在服务端struts的拦截器里response中加一个状态标识,类似如下,这是我的loginInterceptor
	@Override
	public String intercept(ActionInvocation invocation) throws Exception {
		
		LoginInfoVO login = (LoginInfoVO)ServletActionContext.getRequest().getSession().getAttribute("login");

		//如果为空,则返回到登录页面
		if(login == null){
			ServletActionContext.getResponse().setStatus(501);
			return "login";
		}
		
		//继续向下执行
		return invocation.invoke();
	}


ajax的textStatus经测试只有两种状态成功为“success”,失败为“error”;所以如果在response中设置http错误状态码就OK!
1 楼 shanghaiwobama 2012-09-02  
好,刚好我们做项目下一步也要用这个,,,,