1.在前端接收request里返回的状态码进行判断

tools.setAjaxGlobal = function () {
$(document).ajaxComplete(function (event, request, settings) {
if (settings.url && settings.url.indexOf("/logout") >= 0) {
return;
}
if (location.href.indexOf("/login") != -1) {
return;
}
if (!top.page.dialogExt) {
return;
}
if (request.status == 404) {
//将之前其他dialog弹出框,以及遮盖删除
top.page.warn("请求未找到!", "提示");
}
if (request.status == 403) {
/*操作权限不足*/
top.page.warn("操作权限不足!", "提示", function () {
top.page.doLogout(true);
});
}
if (request.status == 500) {
//系统异常
top.page.warn("系统异常!", "提示信息");
}
if (request.status == 800) {
//会话过期
top.page.warn("会话已过期,请重新登陆", "提示信息", function () {
top.page.doLogout(true);
});
}
if (request.status == 900) {
//会话过期
top.page.warn("该用户已在其它地方登录,请重新登录", "提示信息", function () {
top.page.doLogout(true);
});
}
});
};

2.创建类SecurityInterceptor,继承HandlerInterceptor(springMVC中的拦截器),在其中判断超时

public class SecurityInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
/*该方法将在请求处理之前进行调用,只有该方法返回true,才会继续执行后续的Interceptor和Controller,当返回值为true 时就会继续调用下一个Interceptor的preHandle 方法,如果已经是最后一个Interceptor的时候就会是调用当前请求的Controller方法;
SysUser user = (SysUser) HttpUtils.getSession().getAttribute("userBean");
if (user != null) {
return true;
}
// 登录超时返回800
response.setStatus(800);
return false;
}
  @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response,Object obj,Exception e)throws Exception {
  /*该方法也是需要当前对应的Interceptor的preHandle方法的返回值为true时才会执行,该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行。用于进行资源清理。*/
}
  @Override public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,Object arg2,ModelAndView arg3) throws Exception {
  /*该方法将在请求处理之后,DispatcherServlet进行视图返回渲染之前进行调用,可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作。
  }

}

3.配置拦截,addPathPatterns表示拦截哪些功能,excludePathPatterns表示不拦截哪些功能(比如登录相关,验证码)

@Configuration
public class WebConfig extends WebMvcConfigurerAdapter {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new SecurityInterceptor())
.addPathPatterns("/**")
.excludePathPatterns("/login/**");
}
}