[JS] Ajax请求会话过期处理
2015-12-15 15:17
477 查看
对于页面来说,处理session过期比较简单,一般只需在过滤器里面判断session用户是否存在,不存在则跳转页面到登陆页即可。
对于Ajax请求来说,这个办法则无效,只能获取到登录页的html代码。原因在于Ajax请求是XMLHTTPRequest对象发起的而不是浏览器,而服务器返回的信息接收者也是XMLHTTPRequest,非浏览器。
解决办法:
服务器端
可在返回的ResponseHeader里添加一个标识变量,以便在Javascript里处理。以Java为例,可在过滤器里进行如下处理:
Javascript端
可通过JQuery的ajaxComplete方法进行处理,判断发送请求时是否会话已过期。
对于Ajax请求来说,这个办法则无效,只能获取到登录页的html代码。原因在于Ajax请求是XMLHTTPRequest对象发起的而不是浏览器,而服务器返回的信息接收者也是XMLHTTPRequest,非浏览器。
解决办法:
服务器端
可在返回的ResponseHeader里添加一个标识变量,以便在Javascript里处理。以Java为例,可在过滤器里进行如下处理:
try { // Ajax请求会话过期处理 String requestType = request.getHeader("X-Requested-With"); if (StringUtils.isNotEmpty(requestType) && requestType.equalsIgnoreCase("XMLHttpRequest")) { response.setHeader("SessionStatus", "sessionTimeOut"); requestContext.abortWith(Response.status(401).build()); return; } // 处理页面跳转 requestContext.abortWith(Response.accepted().build()); response.sendRedirect(loginPath); } catch (IOException ex) { //do nothing }
Javascript端
可通过JQuery的ajaxComplete方法进行处理,判断发送请求时是否会话已过期。
/** * ajax请求判断会话是否已过期 */ $(document).ajaxError(function (event, jqXHR, options, errorMsg) { var sessionStatus = jqXHR.getResponseHeader('SessionStatus'); if (sessionStatus && sessionStatus === 'sessionTimeOut') { alert("您的会话已过期,请重新登录"); location.href = "login"; } });
相关文章推荐
- Adroid开发之解析Json数据格式
- Ext JS权威指南
- js----验证码
- Google Map JavaScript API V3 实例大全
- JavaScript笔记
- JavaScript 静态方法和实例方法
- js checkbox获取选中的值
- firedac的数据序列和还原单元(Data.FireDACJSONReflect.pas)之字符串序列和还原
- 【层级结构】Ext.js5 视图模型的内部
- 前后台彻底分离的核心文件bridge.js.
- js中数组的使用
- firedac的数据序列和还原单元(Data.FireDACJSONReflect.pas)之拷贝FIREDAC数据集
- 转 JavaScript 获取鼠标点击位置坐标
- JavaScript组件开发完整示例
- js判断输入字符串长度(汉字算两个字符,字母数字算一个)
- JavaScript我的常用函数库
- JavaScript我的常用函数库
- jsp 关于导出excel 自动转换 科学计数法 显示的问题
- JS--简易心形
- Json对象与Json字符串互转