Ext下,ajax请求和普通http请求,session超时转到登录页面的解决方案

 对于web应用系统,通常会有以下场景:session超时之后,用户在浏览器中发出请求时将作出session超时的判断,然后系统跳转到登陆页面,提示用户重新登录。
       问题在于,对于普通的http请求,可以通过拦截器判断session超时,然后跳转到登录页面;但是对于Ajax请求,则不会如期待的那样自动转到登录页面,若想实现,必须特殊处理。
      调试中发现,不论是普通http请求还是ajax请求,都可以通过拦截器来将请求捕获,而且区分这两种请求在于头部信息的不同:普通http请求的header参数中没有x-requested-with:XMLHttpRequest头信息,而异步的有。

     

       系统是基于ext的ajax框架,通过上网查资料,发现一个比较好的且对原系统改动很小的解决方案:
       首先在session超时后,通过拦截器将ajax请求拦截,为该请求的设置一个头部信息以标识其超时;然后,由于Ext.ajax是全局单一ajax实例,因此注册Ext.Ajax的requestcomplete事件,每个ajax请求成功后首先响应该事件。在该事件的回调函数里面判断访问请求是否超时。使用Ext.Ajax对象的好处是,只需要引入一个包含了几行超时处理代码的js文件,就可以为当前应用增加超时处理功能,原有代码不需要做任何修改。

[java]  view plain  copy
  1. // 拦截器的处理:  
    1. // 拦截器的处理:  
    2. if (request.getHeader("x-requested-with") != null  
    3.                         && request.getHeader("x-requested-with")  
    4.                                 .equalsIgnoreCase("XMLHttpRequest")) {  
    5.                     PrintWriter printWriter = response.getWriter();  
                     //如果是ajax请求响应头会有,x-requested-with  
      printWriter.write("timeout");
                     //return false;  
                  }
      printWriter.flush();
      printWriter.close();
    6.                 }  

[javascript]  view plain  copy
  1. // ajax回调函数处理系统退出  
    Ext.Ajax.on('requestcomplete',checkUserSessionStatus, this);     
    function checkUserSessionStatus(conn,response,options){ //
        //Ext重新封装了response对象     
        if(response.responseText=='timeout'){     
            Ext.Msg.alert('提示', '您的登录已超时,请重新登录!', function() {
            parent.location.href=contextPath+'/index.do'
             }); 
        }     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值