【文件属性】:
文件名称:Ajax请求session超时处理流程
文件大小:4KB
文件格式:JS
更新时间:2013-03-05 09:26:55
Ajax session超时处理
Ajax请求session超时处理流程
java服务器端处理:
SessionValidateFilter中修改:
if (ServerInfo.isAjax(request)) {
request.setAttribute("statusCode", 301);
request.setAttribute("message", "Session timeout!");
response.sendRedirect(response.encodeRedirectURL("/ajaxDone.jsp");
else {
response.sendRedirect(response.encodeRedirectURL(this.loginUrl + java.net.URLEncoder.encode(backToUrl, "UTF-8")));
}
ajaxDone.jsp页面
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>
{
statusCode:${statusCode}, message:"${message}", objectId:"${objectId}"
}
js客户端处理:
ajax load页面碎片处理:
自己写一个loadUrl()方法,不能使用jquery自带的load().
当客户端调用loadUrl()超时,弹出一个登录框,并加一个背景层下面的整个浏览器.这时浏览器窗口内容不能变,只是上面加了一个登录框和一个背景层
当用户输入username and password登录成功后,去掉登录框和背景层.这时用户可以继续操作.
登录失败alert出错信息,浏览器窗口内容还是不变.
var DWZ = {
loginUrl:"/render.do?method=login",
ajaxDoneEval:function (json) { //session timeout
try{
return eval('(' + json + ')');
} catch (e){
return {};
}
}
};
(function($){
$.extend({
loadUrl: function(url,data,callback){
var aData = data || {};
aData["timestamp"] = new Date().getTime();
var $this = $(this);
$.get(url, aData, function(data){
var json = DWZ.ajaxDoneEval(data);
if (json.statusCode==301){
alertMsg.error(json.message, {okCall:function(){
window.location = "/render.do?method=login";
//popLoginWin();
}});
} else {
$this.html(data).initUI();
if (jQuery.isFunction(callback)) callback();
}
});
}
});
})(jQuery);
ajax post 表单数据处理:
当客户端ajax提交表单超时, 弹出一个登录框,并加一个背景层下面的整个浏览器.
当用户输入username and password登录成功后,去掉登录框和背景层.这时用户可以继续操作.
登录失败alert出错信息.
$.post(form.action, params, callback(json){
if (json.statusCode == 301) { //301 状态表示 session timeout
popLoginWin();
}else if (json.statusCode == 300) { //300 状态表示 操作失败
alertMsg.error(json.message);
} else if(json.statusCode == 200) { //300 状态表示 操作成功
alertMsg.correct(json.message);
}
},
"json");
网友评论
- 呵,都不用下载了,直接给出方案。
- 不错,代码很好,值得参考
- 不错,正要相关系的资料。
- 正是我要找的资源,很满意
- 我急需ajax的资料,补助直接的薄弱
- 和贴出来的那一大块一样
- 呵,都不用下载了,直接给出方案。