session失效,使用ajax请求数据被拦截,此时正常的处理逻辑是跳到登录界面,而不是界面没有变化(java判断是否是ajax请求)

在登录过滤器中,判断请求是ajax请求还是超链接或者地址栏变化的请求

 if (httpServletReq.getHeader("x-requested-with") != null
                            && httpServletReq.getHeader("x-requested-with").equalsIgnoreCase("XMLHttpRequest"))
                    {
                        JSONObject jsessiontimeout = new JSONObject();
                        jsessiontimeout.put("sessiontimeout", true);
                        response.getWriter().print(jsessiontimeout.toString());
                        response.getWriter().flush();
                        response.getWriter().close();
                    }
                    else {
                        goLogin(httpServletReq, httpServletRes);
                    }

js

/*******************************************************************************
 * 判断session是否超时,所有动态请求都需要进行判断
 ******************************************************************************/
function cheackSessionTimeOut(data){
 
 if(isJson(data))
 {
  if(data.sessiontimeout==true){
    //重装浏览器地址栏的地址,跳到登陆页面
   window.location.reload();
  }
 }
};

在所有ajax请求数据成功之后都调用 cheackSessionTimeOut(data);

 $.post(
        url,
        {},
        function(data)
        {   
           cheackSessionTimeOut(data);
        }    
     );  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值