如處理不當會影響使用者體驗,也有可能產生莫名的問題。
結合自己的思考和網上相關內容的參考,給出如下解決方案。
方案1:檢查AJAX返回的返回的內容是否有<html>標籤
在web系統中,當session到期時,當使用者有操作的時候,此時系統一般會返回登陸介面。
讓使用者重新輸入使用者名稱和密碼。當session到期的時候,AJAX請求返回的內容應該是登陸介面的頁面
內容(即登陸介面的頁面的html代碼)。通過判斷返回內容是否用<html>來判斷session是否到期。
var result=request.responseText;/* ajax返回的內容*/
if(result.indexOf('<HTML>')>-1){/*返回內容中有html標籤*/}
或者
var r=/<html>/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保持長串連)