现在很多菜单的内容都是通过Ajax加载来呈现的,那么如果遇到session失效,该证明处理呢?
其实方法不难,Ajax请求的请求头X-Requested-With的值为XMLHttpRequest。后台通过request获取到这个请求头,就知道是普通的http请求还是Ajax请求。如果是Ajax请求,那么可以添加一个响应头,然后页面上Ajax完成时,获取请求头,判断做相应处理就可以了。
后端:
// 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。
前端:
/**
* 设置未来(全局)的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}/";
});
}
}
});