浏览 5105 次
精华帖 (0) :: 良好帖 (1) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2010-03-30
的问题,如处理不当会影响用户体验,也有可能产生莫名的问题。 结合自己的思考和网上相关内容的参考,给出如下解决方案。每个方案都有不同的优缺点,欢迎 大家指正。 方案1:检查AJAX返回的返回的内容是否有<html>标签 在web系统中,当session过期时,当用户有操作的时候,此时系统一般会返回登陆界面。 让用户重新输入用户名和密码。当session过期的时候,AJAX请求返回的内容应该是登陆界面的页面 内容(即登陆界面的页面的html代码)。通过判断返回内容是否用<html>来判断session是否过期。 var result=request.responseText;/* ajax返回的内容*/ if(result.indexOf('<HTML>')>-1){/*返回内容中有html标签*/} 或者 var r=/<html>/ig; if(r.test(result)){/*返回内容中有html标签*/} 通过上面的方法可以判断session是否过期,然后根据具体的业务进行异常处理。 方案2:返回的结果中有session是否过期的标志。也有人称为true/false模式 此解决方案一般结合json使用。 如返回的结果是: var res={ "result":true,/*session没有过期,false(session过期)*/ "data" :""/*其它数据*/ } if(res["result"]) { /*session没有过期*/ }else{ /*session过期*/ } 方案3:利用时间戳 在页面上搞个全局变量 var startDate; /*ajax最近一次访问服务器的时间,Date类型*/ if(new Date().getTime()-startDate.getTime()<30*60*1000) { /*假设session过期的时间30分钟*/ /*session没有过期*/ }else{ /*session过期*/ } 哈哈!Do not trust the client 方案4:延长session过期时间 此方案有性能问题 4.1:延长session过期时间 4.2:client轮循server。(AJAX轮循server或client,server保持长连接) 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2010-03-30
方案2是正统的方法, 其他的都不太好.
不过就算是方案2依然会出现服务端生成json的时候result:true,但是当json返回到客户端时刚好超时了.怎么搞? |
|
返回顶楼 | |
发表时间:2010-03-30
Applicaiton.save();
|
|
返回顶楼 | |
发表时间:2010-03-30
我认为当用户session超时或其他session超时 的时候,那调用后台的时候一定会throw excpetion.那会throw exception就一定证明了这个ajax的请求是失败的。而且可以在返回结果中记录出了什么错,然后返回给客户。
PS:这不算是设计模式里的东西吧 |
|
返回顶楼 | |
发表时间:2010-03-31
刚好超时几率很小把....忽略不计是可以的把..
第二种不错... |
|
返回顶楼 | |
发表时间:2010-04-01
现在没遇到过 我觉得第二种比较好
|
|
返回顶楼 | |
发表时间:2010-04-01
nishizhutoua 写道 方案2是正统的方法, 其他的都不太好.
不过就算是方案2依然会出现服务端生成json的时候result:true,但是当json返回到客户端时刚好超时了.怎么搞? 当json返回到客户端时刚好超时了 这个问题不用考虑。就是jsp也不会传输时间的。 |
|
返回顶楼 | |
发表时间:2010-04-01
我也认为得第二种比较好,不过,你一个ajax请求而已,返回的时候居然就过期了,这个时间也太久了点。。
|
|
返回顶楼 | |