当前位置 主页 > 网站技术 > 代码类 >

    JS Ajax请求会话过期处理问题解决方法分析

    栏目:代码类 时间:2019-11-16 15:09

    本文实例讲述了JS Ajax请求会话过期处理问题解决方法。分享给大家供大家参考,具体如下:

    对于页面来说,处理session过期比较简单,一般只需在过滤器里面判断session用户是否存在,不存在则跳转页面到登陆页即可。

    对于Ajax请求来说,这个办法则无效,只能获取到登录页的html代码。原因在于Ajax请求是XMLHTTPRequest对象发起的而不是浏览器,而服务器返回的信息接收者也是XMLHTTPRequest,非浏览器。

    解决办法:

    服务器端

    可在返回的ResponseHeader里添加一个标识变量,以便在Javascript里处理。以Java为例,可在过滤器里进行如下处理:

    try {
      // Ajax请求会话过期处理
      String requestType = request.getHeader("X-Requested-With");
      if (StringUtils.isNotEmpty(requestType) && requestType.equalsIgnoreCase("XMLHttpRequest")) {
        response.setHeader("SessionStatus", "sessionTimeOut");
        requestContext.abortWith(Response.status(401).build());
        return;
      }
      // 处理页面跳转
      requestContext.abortWith(Response.accepted().build());
      response.sendRedirect(loginPath);
    } catch (IOException ex) {
      //do nothing
    }
    
    

    Javascript端

    可通过JQuery的ajaxComplete方法进行处理,判断发送请求时是否会话已过期。

    /**
     * ajax请求判断会话是否已过期
     */
    $(document).ajaxError(function (event, jqXHR, options, errorMsg) {
      var sessionStatus = jqXHR.getResponseHeader('SessionStatus');
      if (sessionStatus && sessionStatus === 'sessionTimeOut') {
        alert("您的会话已过期,请重新登录");
        location.href = "login";
      }
    });
    
    

    更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript中ajax操作技巧总结》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

    希望本文所述对大家JavaScript程序设计有所帮助。