如何使Session永不過期


用在要保持session的頁里設隱藏iframe每隔一段時間(這個時間小於session.timeout的時間)把涮 新一次frame里的空頁面!實現方法如下:


      在要保持session頁里加上: 
<iframe width=0 height=0 src="SessionKeeper.asp">
</iframe>


      同目錄下建一下SessionKeeper.asp的文件。 
<html>
<head>
  <meta http-equiv="Refresh" content="900000;url=sessionKeeper.asp"> 
  <!--每隔900秒刷新一下自己,為了和服務器通訊一下,保持session不會丟-->
</head>
</html>


        這種方法還是比較長見的,但是我自己沒有實現,另外還有一種和上面類似的方法,不過他不是用meta自動涮新嵌套的iframe的方法。他是用javascript: window.setTimeout("functionname()",10000);第隔一段時間時間自動調用一個函數的方法,當然函數里還是要去連接一個空的文件。具體方法如下:
     

        在要保持session面里加上: 
<script  id=Back  language=javascript></script>
<script language=javascript>
 function keepsession(){
  document.all["Back"].src="SessionKeeper.asp?RandStr="+Math.random();
  //這里的RandStr=Math.random只是為了讓每次back.src的值不同,防止同一地址刷新無效的情況
  window.setTimeout("keepsession()",900000);  //每隔900秒調用一下本身
  }
 keepsession();
</script>
這樣同一目錄下建一個空內容的sessionKeeper.asp就文件就可以了! 這個可以使用!!!!!!!
    

        問題沒有解決:通過以上的方法Session保持應該沒有問題了,IIS默認無請求的清除session的值為20分鍾,我設的每次交互服務的時間都遠遠小於這個值,可是我大概過個一天多的時間,session還是無緣無故的沒了!郁悶。

        后來在網上多方查找終於找到答案:原來IIS為了保護服務器,有一個“回收”的概念!測試了半天終於有了點大體了解(不要笑我菜^-^)。先來看看這個“回收”在哪設置。


        啟動IIS管理器->應用程序池->右鍵->屬性->回收選項卡,有一項是默認就起作用的,就是第一項:“回收工作進程(分 鍾)”默認值1740分鍾,大約29個小時。他是什么意思呢?我個人理解:在session.timeout之后再過1740分鍾自動把所有仍在保持的session清除。這個值最大可設為4000000,大概是2700多天!我直接取消了,不用他自動回收!問題終於解決。


        另外這個屬性對話框中還有其它幾項:第二項應該是連接的用戶超過了一定數目回收。第三項是到某一個時間就自動回收。在“性能”選項卡中“在空閑此時間段后 關閉工作進程”,這里就是設置IIS默認session.timeout時間的地方了。默認值20分鍾,這里同樣最大值可設為4000000,和在ASP 頁中設置session.timeout最大值為1440不同。在這里設置超過大於1440的值是否起作用,我沒作測試,我想應該是可以的。那為什么在 ASP頁中session.timeout的值最大只能是1440在IIS的屬性中卻能設的那么大呢?應該是屬於一種保護機制:ASP頁的 session.timeout的值哪個用戶都可以設,IIS里卻只有管理員可以設,兩者的權限不同,所以設置的范圍就不同了。

以上都是在網上查找的方法,第二種方法是可用的,但是如果遇到【模態畫面】好像就不行了,經過調試發現每隔一段時間訪問服務器端的空畫面沒有被執行,不知道為什么,就把方法修改一個是針對模態畫面的session Timeout

<iframe id="SessionGoOn" src="./SessionGoOn.aspx" style="width: 213px; height: 213px; display: none;"></iframe>

  1.以下的方法是模態窗口保持Session 

<script type="text/javascript"> 
         var timer;
        //每隔10分鍾定向訪問
        timer = setInterval(function () { document.getElementById('SessionGoOn').contentDocument.location.href = document.getElementById('SessionGoOn').contentDocument.location.href; }, 600000);
    </script>

  2.以下是正常畫面保持Session

<script type="text/javascript"> 
         var timer;
        //每隔10分鍾刷新服務器空畫面
        timer = setInterval(function () { document.getElementById('SessionGoOn').contentDocument.location.reLoad(true); }, 600000);
    </script>

Loaction.ReLoad 如果該方法沒有規定參數,或者參數是 false,它就會用 HTTP 頭 If-Modified-Since 來檢測服務器上的文檔是否已改變。如果文檔已改變,reload() 會再次下載該文檔。如果文檔未改變,則該方法將從緩存中裝載文檔。這與用戶單擊瀏覽器的刷新按鈕的效果是完全一樣的。

如果把該方法的參數設置為 true,那么無論文檔的最后修改日期是什么,它都會繞過緩存,從服務器上重新下載該文檔。這與用戶在單擊瀏覽器的刷新按鈕時按住 Shift 健的效果是完全一樣。  

兩種方式都已經測試成功,注意:方法1可以被方法2的畫面所使用,但是方法2不能被方法1的畫面使用


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM