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!