在struts2的拦截器中判断session是否失效,如果失效了,通过request的头信息判断是ajax请求还是普通请求。对于ajax请求,需要直接返回response的error信息,这样ajax就不再请求后台了,直接返回error;同时可以在response的头信息中设置session timeout等相应状态。



if (UserCache.getFromSession() == null) {
<span style="white-space:pre"> </span>logger.error("session失效,当前url:" + servletPath+";
//如果是ajax请求响应头会有,x-requested-with;
if (request.getHeader("x-requested-with") != null
&& request.getHeader("x-requested-with").equalsIgnoreCase("XMLHttpRequest")) {
response.setHeader("sessionstatus", "timeout");//在响应头设置session状态
response.getWriter().print("error");
} else {
request.setAttribute("msg", "长时间未操作,请重新登录!");
return "login";
}
}


使用jquery的全局ajax监听error


$.ajaxSetup({
async : false,
contentType:"application/x-www-form-urlencoded;charset=utf-8",
error:function(XMLHttpRequest,textStatus){
var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus");
if(sessionstatus=="timeout"){
alert("长时间未操作,请重新登录!");
window.location.replace(basePath+"login.jsp");
return;
}
}
});


注:response.getWriter().print("error"); 表示ajax错误返回,直接到了前端的error回调函数

     在拦截器中,最保险的方法是直接 return null