Java中解决(extjs或jquery)session过期退出登录问题

Java中解决(extjs或jquery)session过期退出登录问题

发表于1年前(2013-09-24 18:09)   阅读( 2046) | 评论( 0)  6人收藏此文章, 我要收藏
0

解决两种情况下的用户访问超时:

a)普通http请求的session超时;
b)异步http请求的session超时,如果使用extjs后大部分的界面刷新都是异步的ajax请求。

不管是那种类型的http请求总是可以由一个过滤器来捕捉。
分类:普通http请求的header参数中没有x-requested-with:XMLHttpRequest头信息,而异步的有。
其实对于常见的ajax框架,header中还有标示自己身份的header信息。

对于普通的http请求,发现session超时后直接重定向到一个超时页面,显示访问超时。
对于异步http请求,发现session超时后则向请求的response中写入特定的超时头信息,客户端ajax对象检测
头信息,发现有超时状态标志后调用显示超时信息的javascript方法,提示用户访问超时。

服务器端session超时后在过滤器中为response添加新的头信息,标记该请求超时:

?
1
2
3
if (r.getHeader( "x-requested-with" )!= null <span></span>&& r.getHeader( "x-requested-with" ).equalsIgnoreCase( "XMLHttpRequest" )){
     response.setHeader( "sessionstatus" , "timeout" );
}
使用Ext.Ajaxt对象完成异步请求的交互,Ext.Ajax是单实例对象(非常重要,全局单一Ext.Ajax实例!)。 
注册Ext.Ajax的requestcomplete事件,每个ajax请求成功后首先响应该事件。在该事件的回调函数里面判断 
访问请求是否超时。使用Ext.Ajax对象的好处是,只需要引入一个包含了几行超时处理代码的js文件,就可以 
为当前应用增加超时处理功能,原有代码不需要做任何修改。 

使用Ext.Ajaxt对象完成异步请求交互,假如checkUserSessionStatus是你的回调方法,每个页面引用:

?
1
2
3
4
5
6
7
Ext.Ajax.on( 'requestcomplete' ,checkUserSessionStatus, this );
function checkUserSessionStatus(conn,response,options){
     //Ext重新封装了response对象
     if ( typeof response.getResponseHeader.sessionstatus != 'undefined' ){
         //发现请求超时,退出处理代码...
     }
}
可以利用的几个特性: 
a)所有的ajax请求均带有x-requested-with:XMLHttpRequest头信息 
b)Ext.Ajax是单实例对象(非常重要,全局单一Ext.Ajax实例!) 

c)注册Ext.Ajax的requestcomplete事件,每个ajax请求成功后首先响应该事件(概念类似spring的aop拦截)。

jquery提供了几个全局事件可以用来处理session过期请求,如当ajax请求开始时会触发ajaxStart()方法的回调函数; 当ajax请求结束时,会触发ajaxStop()方法的回调函数。这些方法都是全局的方法,因此无论创建它们的代码位于何处, 只要有ajax请求发生时,都会触发它们。类似的事件还有:ajaxComplete(),ajaxError(),ajaxSend(),ajaxSuccess()等。

?
1
2
3
4
5
$(document).ajaxComplete( function (event,xhr,settings){
     if (xhr.responseText== "timeout" ){
         top.location.href= 'index.php' ;
     }
});

如果使某个ajax请求不受全局方法的影响,那么可以在使用$.ajax()方法时,将参数中的global设置为false,jquery代码如下:

?
1
2
3
4
5
$.ajax({
     url: "test.html" ,
     global: false //不触发全局ajax事件
 
})

对于其他的ajax框架,解决用户访问请求超时这个问题的思路是类似的。

在这里推荐一个很实用的Js方法:

?
1
2
3
4
5
6
7
function getRootWin(){
     var win = window;
     while (win != win.parent){
         win = win.parent;
     }
     return win;
}

通过该方法,可以在一个任意深度的iframe中调用父iframe中的方法。具体到这里就是无论哪一个iframe中的用户访问请求超时,都可以通过该方法调用最外层iframe中的退出方法,这样便为用户提供了一个统一的访问超时退出的UI呈现。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值