熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> .NET編程 >> 正文

ASP.NET Session丟失問題原因及解決方案

2013-11-13 10:36:02  來源: .NET編程 

  正常操作情況下會有ASPNET Session丟失的情況出現因為程序是在不停的被操作排除Session超時的可能另外Session超時時間被設定成分鐘不會這麼快就超時的

  現在我就把原因和解決辦法寫出來

  ASPNET Session丟失原因

  由於Aspnet程序是默認配置所以WebConfig文件中關於Session的設定如下

  <sessionState mode=InProc stateConnectionString=tcpip=: sqlConnectionString=data source=;Trusted_Connection=yes cookieless=true timeout=/>

  我們會發現sessionState標簽中有個屬性mode它可以有種取值InProc StateServer?SQLServer(大小 寫敏感) 默認情況下是InProc也就是將Session保存在進程內(IIS是aspnet_wpexe而IIS是Wwpexe)這個進程不 穩定在某些事件發生時進程會重起所以造成了存儲在該進程內的Session丟失

  哪些情況下該進程會重起呢?微軟的一篇文章告訴了我們

  配置文件中processModel標簽的memoryLimit屬性

  Globalasax或者Webconfig文件被更改

  Bin文件夾中的Web程序(DLL)被修改

  殺毒軟件掃描了一些config文件

  更多的信息請參考PRB: Session variables are lost intermittently in ASPNET applications

  ASPNET Session丟失解決辦法

  前面說到的sessionState標簽中mode屬性可以有三個取值除了InProc之外還可以為StateServer SQLServer這兩種存Session的方法都是進程外的所以當aspnet_wpexe重起的時候不會影響到Session

  現在請將mode設定為StateServerStateServer是本機的一個服務可以在系統服務裡看到服務名為ASPNET State Service的服務默認情況是不啟動的當我們設定mode為StateServer之後請手工將該服務啟動

  這樣我們就能利用本機的StateService來存儲Session了除非電腦重啟或者StateService崩掉否則Session是不會丟的(因Session超時被丟棄是正常的)

  除此之外我們還可以將Session通過其他電腦的StateService來保存具體的修改是這樣的同樣還在sessionState 標簽 中有個stateConnectionString=tcpip=:屬性其中有個ip地址默認為本機 ()你可以將其改成你所知的運行了StateService服務的電腦IP這樣就可以實現位於不同電腦上的Aspnet程序互通 Session了

  如果你有更高的要求需要在服務期重啟時Session也不丟失可以考慮將mode設定成SQLServer同樣需要修改sqlConnectionString屬性關於使用SQLServer保存Session的操作請訪問這裡

  在使用StateServer或者SQLServer存儲Session時所有需要保存到Session的對象除了基本數據類型(默認的數據類型如intstring等)外都必須序列化只需將[Serializable]標簽放到要序列化的類前就可以了

  如

  [Serializable]

  public class MyClass

  {

  

  }

  具體的序列化相關的知識請參這裡

  至此ASPNET Session丟失問題解決

  關於aspnet Session丟失問題的總結

  asp中Session的工作原理

  asp的Session是具有進程依賴性的ASP Session狀態存於IIS的進程中也就是inetinfoexe這個程序所以當inetinfoexe進程崩潰時這些信息也就丟失另外重起或者關閉IIS服務都會造成信息的丟失

  aspnet Session的實現

  ASPNET的Session是基於HttpModule技術做的HttpModule可以在請求被處理之前對請求進行狀態控制由於Session本身就是用來做狀態維護的因此用HttpModule做Session是再合適不過了

  原因

  bin目錄中的文件被改寫aspnet有一種機制為了保證dll重新編譯之後系統正常運行它會重新啟動一次網站進程這時就會導致Session丟失所以如果有access數據庫位於bin目錄或者有其他文件被系統改寫就會導致Session丟失

  原因

  文件夾選項中如果沒有打開“在單獨的進程中打開文件夾窗口”一旦新建一個窗口系統可能認為是新的Session會話而無法訪問原來的Session所以需要打開該選項否則會導致Session丟失

  原因

  似乎大部分的Session丟失是客戶端引起的所以要從客戶端下手看看cookie有沒有打開

  原因

  Session的時間設置是不是有問題會不會因為超時造成丟失

  原因

  IE中的cookie數量限制(每個域個cookie)可能導致session丟失

  原因

  使用web garden模式且使用了InProc mode作為保存session的方式

  ASPNET Session丟失問題解決經驗

   判斷是不是原因造成的可以在每次刷新頁面的時候跟蹤bin中某個文件的修改時間

   做Session讀寫日志每次讀寫Session都要記錄下來並且要記錄SessionIDSession值所在頁面當前函數函數中的第幾次Session操作這樣找丟失的原因會方便很多

   如果允許的話建議使用state server或sql server保存session這樣不容易丟失

   在globalasa中加入代碼記錄Session的創建時間和結束時間超時造成的Session丟失是可以在SessionEnd中記錄下來的

   如果有些代碼中使用客戶端腳本如javascript維護Session狀態就要嘗試調試腳本是不是因為腳本錯誤引起Session丟失(來源傑之藍)


From:http://tw.wingwit.com/Article/program/net/201311/14085.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.