這篇文章主要講解了“如何解決Ajax應用中的session過期問題”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何解決Ajax應用中的session過期問題”吧!
現在web開發中,ajax應用的比較多。關于此方面的框架也不少。在應用中都會遇到session過期的問題,如處理不當會影響用戶體驗,也有可能產生莫名的問題。
結合自己的思考和網上相關內容的參考,給出如下解決方案。每個方案都有不同的優缺點,歡迎大家指正。
方案1:檢查AJAX返回的返回的內容是否有< html>標簽
在web系統中,當session過期時,當用戶有操作的時候,此時系統一般會返回登陸界面。
讓用戶重新輸入用戶名和密碼。當session過期的時候,AJAX請求返回的內容應該是登陸界面的頁面內容(即登陸界面的頁面的html代碼)。通過判斷返回內容是否用< html>來判斷session是否過期。
var result=request.responseText;/* ajax返回的內容*/ if(result.indexOf('')>-1){/*返回內容中有html標簽*/}
或者
var r=//ig; if(r.test(result)){/*返回內容中有html標簽*/}
通過上面的方法可以判斷session是否過期,然后根據具體的業務進行異常處理。
方案2:返回的結果中有session是否過期的標志。也有人稱為true/false模式。此解決方案一般結合json使用。
如返回的結果是:
var res={ "result":true,/*session沒有過期,false(session過期)*/ "data" :""/*其它數據*/ } if(res["result"]) { /*session沒有過期*/ }else{ /*session過期*/ }
方案3:利用時間戳
在頁面上搞個全局變量
var startDate; /*ajax最近一次訪問服務器的時間,Date類型*/ if(new Date().getTime()-startDate.getTime()< 30*60*1000) { /*假設session過期的時間30分鐘*/ /*session沒有過期*/ }else{ /*session過期*/ }
哈哈!Do not trust the client
方案4:延長session過期時間
此方案有性能問題
4.1:延長session過期時間
4.2:client輪循server。(AJAX輪循server或client,server保持長連接)
感謝各位的閱讀,以上就是“如何解決Ajax應用中的session過期問題”的內容了,經過本文的學習后,相信大家對如何解決Ajax應用中的session過期問題這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。