現(xiàn)在web開(kāi)發(fā)中,ajax應(yīng)用的比較多。關(guān)于此方面的框架也不少。在應(yīng)用中都會(huì)遇到session過(guò)期
的問(wèn)題,如處理不當(dāng)會(huì)影響用戶體驗(yàn),也有可能產(chǎn)生莫名的問(wèn)題。
結(jié)合自己的思考和網(wǎng)上相關(guān)內(nèi)容的參考,給出如下解決方案。每個(gè)方案都有不同的優(yōu)缺點(diǎn),歡迎
大家指正。
方案1:檢查AJAX返回的返回的內(nèi)容是否有<html>標(biāo)簽
在web系統(tǒng)中,當(dāng)session過(guò)期時(shí),當(dāng)用戶有操作的時(shí)候,此時(shí)系統(tǒng)一般會(huì)返回登陸界面。
讓用戶重新輸入用戶名和密碼。當(dāng)session過(guò)期的時(shí)候,AJAX請(qǐng)求返回的內(nèi)容應(yīng)該是登陸界面的頁(yè)面
內(nèi)容(即登陸界面的頁(yè)面的html代碼)。通過(guò)判斷返回內(nèi)容是否用<html>來(lái)判斷session是否過(guò)期。
var result=request.responseText;/* ajax返回的內(nèi)容*/
if(result.indexOf('<HTML>')>-1){/*返回內(nèi)容中有html標(biāo)簽*/}
或者
var r=/<html>/ig;
if(r.test(result)){/*返回內(nèi)容中有html標(biāo)簽*/}
通過(guò)上面的方法可以判斷session是否過(guò)期,然后根據(jù)具體的業(yè)務(wù)進(jìn)行異常處理。
方案2:返回的結(jié)果中有session是否過(guò)期的標(biāo)志。也有人稱為true/false模式
此解決方案一般結(jié)合json使用。
如返回的結(jié)果是:
var res={
"result":true,/*session沒(méi)有過(guò)期,false(session過(guò)期)*/
"data" :""/*其它數(shù)據(jù)*/
}
if(res["result"])
{
/*session沒(méi)有過(guò)期*/
}else{
/*session過(guò)期*/
}
方案3:利用時(shí)間戳
在頁(yè)面上搞個(gè)全局變量
var startDate; /*ajax最近一次訪問(wèn)服務(wù)器的時(shí)間,Date類型*/
if(new Date().getTime()-startDate.getTime()<30*60*1000)
{
/*假設(shè)session過(guò)期的時(shí)間30分鐘*/
/*session沒(méi)有過(guò)期*/
}else{
/*session過(guò)期*/
}
哈哈!Do not trust the client
方案4:延長(zhǎng)session過(guò)期時(shí)間
此方案有性能問(wèn)題
4.1:延長(zhǎng)session過(guò)期時(shí)間
4.2:client輪循server。(AJAX輪循server或client,server保持長(zhǎng)連接)