在使用spingMVC的攔截器來處理用戶session失效的問題時,當用戶session失效會返回一串javascript字符串強制用戶瀏覽器跳轉(zhuǎn)至登錄頁面。然而當使用Ajax請求數(shù)據(jù)時,在驗證失敗后只會響應一串字符串,JavaScript并不會執(zhí)行,這是由于Ajax的請求是由XMLHTTPRequest對象發(fā)起的而不是瀏覽器,在驗證失敗后服務器返回的信息會被XMLHTTPRequest對象接收到并保存在js對象中。
為了應對這種情況,可以在后臺對Http請求先進行判斷,將Ajax請求與普通http請求分開處理。
觀察Ajax發(fā)送的請求頭信息可以發(fā)現(xiàn),Ajax請求的頭信息中會帶有X-Requested-With:XMLHttpRequest,通過這個可以判斷是否是Ajax請求。
String requestType = request.getHeader("X-Requested-With");
if(requestType != null "XMLHttpRequest".equalsIgnoreCase(requestType.trim())) {
//如果是ajax請求
response.setHeader("sessionStatus", "timeout");
response.sendError(601, "session timeout.");
return false;
}
javascript代碼,可以設(shè)置Ajax請求的全局默認options,一勞永逸
//設(shè)置Ajax請求的全局默認options
jQuery.ajaxSetup({
type:'post',
complete:function(xhr, ts){ //XMLHttpRequest, textStatus
var sessionStatus = xhr.getResponseHeader('sessionstatus');
if(sessionStatus == 'timeout') {
alert('頁面過期,請重新登錄!');
window.top.location.href = 'Login.htm';
}
}
});
項目中還使用到了DataTables做數(shù)據(jù)表格,發(fā)現(xiàn)用上邊javascript的配置方法在datatables中不能生效,錯誤信息參見:http://datatables.net/tn/7 要配置ajax的error屬性才可以
$('#example').dataTable( {
"ajax": {
"url": "findRoles.htm",
"type": "POST",
"error": function(xhr, ts, et) { //XMLHttpRequest, textStatus, errorThrown
var sessionStatus = xhr.getResponseHeader('sessionstatus');
if(sessionStatus == 'timeout') {
alert('頁面過期,請重新登錄!');
window.top.location.href = 'Login.htm';
}
}
}
});
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- Ajax異步文件上傳與NodeJS express服務端處理
- 完美解決ajax訪問遇到Session失效的問題
- ajax請求Session失效問題
- Ajax請求session失效該如何解決
- Ajax Session失效跳轉(zhuǎn)登錄頁面的方法
- ajax 操作全局監(jiān)測,用戶session失效的解決方法
- express如何解決ajax跨域訪問session失效問題詳解