在拦截器或过滤器中加入如下代码
在header中加入sessionstatus(ajax请求不要执行重定向sendRedirect)
/**------处理ajax请求----start---**/
if("XMLHttpRequest".equals(request.getHeader("X-Requested-With"))){
response.setHeader("sessionstatus", "timeout");
response.setHeader("redirectUrl", "http://www.baidu.com");
}else{
response.sendRedirect("http://www.baidu.com");
}
/**------处理ajax请求----end---**/
页面引入jquery ajax请求的通用代码(特定ajax请求处理后执行)
解析header中的sessionstatus
//全局的AJAX访问,处理AJAX清求时SESSION超时 $.ajaxSetup({ contentType : "application/x-www-form-urlencoded;charset=utf-8", complete : function(XMLHttpRequest, textStatus) { // 通过XMLHttpRequest取得响应头,sessionstatus var sessionstatus = XMLHttpRequest.getResponseHeader("sessionstatus"); if (sessionstatus == "timeout") { // 这里怎么处理在你,这里跳转的登录页面 window.location.replace(XMLHttpRequest.getResponseHeader("redirectUrl")); } } });