ajax请求重定向解决方案,ajax请求session超时刻重定向解决方案.doc

ajax请求session超时刻重定向解决方案

篇一:ajax,session超时

Ajax请求Session超时问题

我在做项目时有时会遇到session超时问题,如果session超时,平常请求没有什么问题,通过拦截器可以正确跳到登陆页面,可是你如果用ajax请求的话这就出现问题了,因为ajax是异步的,局部刷新,所以登陆界面不会再全页面中显示,他只会显示到页面的一部分当中。所以根据我这几年的经验(突出工作经验)|(根据我在网上找到的一些资料(突出学习能力)),找到了我认为比较好的一种方法。

因为那我用的框架是和struts2集成的 所以就在拦截器中进行设置,

1. 首先判断session是否为空就是判断session是否超时,

2. 如果超时就取出请求的head头信息

request.getHeader(x-requested-with)

如果不为空就和XMLHttpRequest (Ajax标识)进行比较 (request.getHeader(x-requested-with).equalsIgnoreCase(XMLHttpRequest))) 如果相等就说明次请求是ajax请求。

3. 如果是ajax请求就可以

response.setHeader(键,值);设置一个标识来告诉用户这次是ajax请求并且session超时时发出的,

4. 这样那我可以在回调函数中取出自己设置的那个唯一标

XMLHttpRequest.getResponseHeader(); 如果取出的值是和自己在后台中设置的值一样的话,就证明session已经超时,这样就可以设置window.location.replace(登陆界面); 来跳转到登陆界面了。

这样做虽然解决了问题,但是,这样做就会在每个回调函数中写入那些代码,这样的话代码就会显得特别零散,所以呢就想能不能定义一个全局的设置所以就找到了jqery的ajaxSetUp方法 通过ajaxSetUp对jqery的ajax进行全局的判断

(ajaxSetUp就相当于ajax的拦截器),通过设置ajaxSetUp里的complete 它就相当于回调函数,这样那就弥补了上一方法的不足。

我做项目时还用到

$(document).ajaxStart();

这是ajax请求时的事件

$(document).ajaxSuccess(),

这是AJAX 请求成功后的事件

我一般用他们来显示遮罩层和隐藏遮罩层用的加遮罩层是为了不让用户重复提交,更提高了用户体验度,让用户知道已经提交了,

篇二:jQuery调用AJAX异步操作超清晰教程

JQUERY AJAX异步操作详细说明

AJAX 全称 Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。它并非一种新的技术,而是以下几种原有技术的结合体。 1)使用CSS和XHTML来表示。

2)使用DOM模型来交互和动态显示。

3)使用XMLHttpRequest来和服务器进行异步通信。

4)使用javascript来绑定和调用。

通过AJAX异步技术,可以在客户端脚本与web服务器交互数据的过程中使用XMLHttpRequest对象来完成HTTP请求(Request)/应答(Response)模型: 1)不需要用户等待服务端响应。在异步派发XMLHttpRequest请求后控制权马上就被返回到浏览器。界面不会出现白板,在得到服务器响应之前还可以友好的给出一个加载提示。

2)不需要重新加载整个页面。为XMLHttpRequest注册一个回调函数,待服务器响应到达时,触发回调函数,并且传递所需的少量数据。“按需取数据”也降低了服务器的压力。

3)不需要使用隐藏或内嵌的框架。在XHR对象之前,模拟Ajax通信通常使用hack手段,如使用隐藏的或内嵌的框架(

XMLHttpRequest对象(XHR)

XMLHttpRequest是一套可以在Javascript、VbScript、Jscript等脚本语言中通过http协议传送或接收XML及其他数据的一套API。

XMLHttpRequest对象首次以ActiveX对象形式在微软Internet Explorer(IE) 5中以引入。其他浏览器制造商在认识到这一对象重要性后也纷纷实现了XMLHttpRequest对象,但是以一个本地JavaScript对象而不是作为一个ActiveX对象实现。而如今,由于安全性、标准等问题,微软已经在其IE 7中把XMLHttpRequest实现为一个本地Java

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值