JS Ajax請(qǐng)求會(huì)話過期處理問題解決方法分析
本文實(shí)例講述了JS Ajax請(qǐng)求會(huì)話過期處理問題解決方法。分享給大家供大家參考,具體如下:
對(duì)于頁(yè)面來說,處理session過期比較簡(jiǎn)單,一般只需在過濾器里面判斷session用戶是否存在,不存在則跳轉(zhuǎn)頁(yè)面到登陸頁(yè)即可。
對(duì)于Ajax請(qǐng)求來說,這個(gè)辦法則無效,只能獲取到登錄頁(yè)的html代碼。原因在于Ajax請(qǐng)求是XMLHTTPRequest對(duì)象發(fā)起的而不是瀏覽器,而服務(wù)器返回的信息接收者也是XMLHTTPRequest,非瀏覽器。
解決辦法:
服務(wù)器端
可在返回的ResponseHeader里添加一個(gè)標(biāo)識(shí)變量,以便在Javascript里處理。以Java為例,可在過濾器里進(jìn)行如下處理:
try {
// Ajax請(qǐng)求會(huì)話過期處理
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;
}
// 處理頁(yè)面跳轉(zhuǎn)
requestContext.abortWith(Response.accepted().build());
response.sendRedirect(loginPath);
} catch (IOException ex) {
//do nothing
}
Javascript端
可通過JQuery的ajaxComplete方法進(jìn)行處理,判斷發(fā)送請(qǐng)求時(shí)是否會(huì)話已過期。
/**
* ajax請(qǐng)求判斷會(huì)話是否已過期
*/
$(document).ajaxError(function (event, jqXHR, options, errorMsg) {
var sessionStatus = jqXHR.getResponseHeader('SessionStatus');
if (sessionStatus && sessionStatus === 'sessionTimeOut') {
alert("您的會(huì)話已過期,請(qǐng)重新登錄");
location.href = "login";
}
});
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- jQuery ajax全局函數(shù)處理session過期后的ajax跳轉(zhuǎn)問題
- ajax實(shí)現(xiàn)session不過期(避免頁(yè)面過期的現(xiàn)象)
- ajax session過期問題的幾個(gè)解決方案
- 淺析ajax請(qǐng)求json數(shù)據(jù)并用js解析(示例分析)
- 跨域請(qǐng)求之jQuery的ajax jsonp的使用解惑
- 原生 JS Ajax,GET和POST 請(qǐng)求實(shí)例代碼
- js每隔5分鐘執(zhí)行一次ajax請(qǐng)求的實(shí)現(xiàn)方法
- JS實(shí)現(xiàn)定時(shí)任務(wù)每隔N秒請(qǐng)求后臺(tái)setInterval定時(shí)和ajax請(qǐng)求問題
- 詳解JavaScript for循環(huán)中發(fā)送AJAX請(qǐng)求問題
- 分享JavaScript監(jiān)聽全部Ajax請(qǐng)求事件的方法
- 淺談js的ajax的異步和同步請(qǐng)求的問題
相關(guān)文章
詳解JS如何解決大數(shù)據(jù)下滾動(dòng)頁(yè)面卡頓問題
之前遇到不分頁(yè)直接獲取到全部數(shù)據(jù),前端滾動(dòng)查看數(shù)據(jù),頁(yè)面就挺卡頓的,所以這篇文章來和大家聊聊如何解決這一問題,感興趣的小伙伴可以了解下2023-07-07
BooStrap對(duì)導(dǎo)航條的改造實(shí)踐小結(jié)
這篇文章主要介紹了BooStrap對(duì)導(dǎo)航條的改造實(shí)踐小結(jié)的相關(guān)資料,本文分步驟介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
js控制的回到頁(yè)面頂端goTop的代碼實(shí)現(xiàn)
在瀏覽網(wǎng)頁(yè)的時(shí)候應(yīng)該會(huì)經(jīng)常見到右下角有個(gè)【回到頂端】的懸浮東東,本文也要使用js實(shí)現(xiàn)一下,感興趣的朋友可以參考下哈,希望可以幫助到你2013-03-03
在點(diǎn)擊div中的p時(shí),如何阻止事件冒泡
本文主要介紹了在點(diǎn)擊div中的p時(shí),如何阻止事件冒泡的方法,具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-02-02
Bootstrap基本組件學(xué)習(xí)筆記之下拉菜單(7)
這篇文章主要為大家詳細(xì)介紹了Bootstrap基本組件學(xué)習(xí)筆記之下拉菜單,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12

