您好,登錄后才能下訂單哦!
本文實例講述了JS Ajax請求會話過期處理問題解決方法。分享給大家供大家參考,具體如下:
對于頁面來說,處理session過期比較簡單,一般只需在過濾器里面判斷session用戶是否存在,不存在則跳轉頁面到登陸頁即可。
對于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"; } });
更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript中ajax操作技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。