调用ajax时session过期的处理方法

前端之家收集整理的这篇文章主要介绍了调用ajax时session过期的处理方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

首先在js文件添加如下代码

  1. $.ajaxSetup({
  2. contentType:"application/x-www-form-urlencoded;charset=utf-8",complete:function(XMLHttpRequest,textStatus){
  3. var sessionstatus=XMLHttpRequest.getResponseHeader("sessionstatus");
  4. if(sessionstatus=="sessionOut"){
  5. location.href = "../login.jsp?t=" + new Date().getTime();
  6. }
  7. }
  8. });

以上代码调用ajax之前先执行。

然后在Filter中添加如下代码

  1. HttpSession session = request.getSession(true);
  2. if (request.getHeader("x-requested-with") != null && request.getHeader("x-requested-with")
  3. .equalsIgnoreCase("XMLHttpRequest") && session.getAttribute("loginID") == null){
  4. response.setHeader("sessionstatus","sessionOut");
  5. response.getWriter().print("sessionOut");
  6. }else{
  7. chain.doFilter(req,res);
  8. }

当判断session.getAttribute("loginID")为空时,证明session过期,此时complete中的代码被执行。

其中location.href中添加类似于url?xxx=随机数是为了防止JSP页面的缓存,随机数可以赋值为new Date().getTime()。

猜你在找的Ajax相关文章