现在很多菜单的内容都是通过Ajax加载来呈现的,那么如果遇到session失效,该证明处理呢?

其实方法不难,Ajax请求的请求头X-Requested-With的值为XMLHttpRequest。后台通过request获取到这个请求头,就知道是普通的http请求还是Ajax请求。如果是Ajax请求,那么可以添加一个响应头,然后页面上Ajax完成时,获取请求头,判断做相应处理就可以了。

后端:

1
2
3
4
5
6
7
8
9
10
11
// ajax请求,session超时处理。添加header,页面Ajax设置全局complete处理方法,如果发现请求头包含session timeout,则跳转到登陆页面
String requestType = httpRequest.getHeader("X-Requested-With");
if(StringUtils.isNotBlank(requestType) && requestType.equalsIgnoreCase("XMLHttpRequest")){
    httpResponse.setHeader("sessionstatus", "timeout");
    httpResponse.sendError(518, "session timeout.");
    return;
}

// 普通http请求,直接跳转到登陆页面
((HttpServletResponse) servletResponse).sendRedirect(((HttpServletRequest) servletRequest).getContextPath() + "/user/toLogin");
如上面的代码,在Ajax请求时,添加一个响应头sessionstatus,值为timeout。

前端:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/**
* 设置未来(全局)的AJAX请求默认选项
* 主要设置了AJAX请求遇到Session过期的情况
*/
$.ajaxSetup({
     type: 'POST',
     complete: function(xhr,status) {
     var sessionStatus = xhr.getResponseHeader('sessionstatus');
     if(sessionStatus == 'timeout') {
        layer.confirm('由于您长时间没有操作, session已过期, 请重新登录.',function() {
            window.location.href = "${ctx}/";
        });
     }
    }
 });