ASP.NET SESSION丟失問題解決方案

來源:互聯網
上載者:User
Session丟失的解決辦法小結 

最近在做ASP.NET項目時,測試網站老是取不出Session中的值,在網上搜尋了一下,找到一些解決方案,記錄在這裡。最後使用儲存在StateServer中的辦法解決了問題。

SessionState 的Timeout),其主要原因有三種

一:有些殺病毒軟體會去掃描您的Web.Config檔案,那時Session肯定掉,這是微軟的說法。
二:程式內部裡有讓Session掉失的代碼,及伺服器記憶體不足產生的。
三:程式有架構頁面和跨域情況。

第一種解決辦法是:使殺病毒軟體屏蔽掃描Web.Config檔案(程式運行時自己也不要去編輯它)
第二種是檢查代碼有無Session.Abandon()之類的。
第三種是在Window服務中將ASP.NET State Service 啟動。

下面是協助中的內容:

(ms-help://MS.VSCC.2003/MS.MSDNQTR.2003FEB.2052/cpguide/html/cpconsessionstate.htm)
ASP.NET 提供一個簡單、便於使用的工作階段狀態模型,您可以使用該模型跨多個 Web 請求儲存任意資料和對象。它使用基於字典的、記憶體中的對象引用(這些對象引用存在於 IIS 進程中)緩衝來完成該操作。使用進程內工作階段狀態模式時請考慮下面的限制: 

使用進程內工作階段狀態模式時,如果 aspnet_wp.exe 或應用程式定義域重新啟動,則工作階段狀態資料將丟失。這些重新啟動通常會在下面的情況中發生: 
在應用程式的 Web.config 檔案的 <processModel> 元素中,設定一個導致新進程在條件被滿足時啟動的屬性,例如 memoryLimit。 
修改 Global.asax 或 Web.config 檔案。 
更改到 Web 應用程式的 Bin 目錄。 
用殺毒軟體掃描並修改 Global.asax 檔案、Web.config 檔案或 Web 應用程式的 Bin 目錄下的檔案。 
如果在應用程式的 Web.config 檔案的 <processModel> 元素中啟用了網路園模式,請不要使用進程內工作階段狀態模式。否則將發生隨機資料丟失。

還有這二種: 

一:在第一個頁面置了SESSION,然後REDIRECT去第二個頁面。解決方案是在REDIRECT中設定endResponse為FALSE。 

二: ASP.NET中使用了ACCESS資料庫,而且資料庫是放在bin目錄中的。解決方案是不要放會更新的檔案在BIN目錄中。 

參考:http://www.dotnet247.com/247reference/msgs/58/290316.aspx

Asp.net 預設配置下,Session莫名丟失的原因及解決辦法
  

正常操作情況下Session會無故丟失。因為程式是在不停的被操作,排除Session逾時的可能。另外,Session逾時時間被設定成60分鐘,不會這麼快就逾時的。

這次到CSDN上搜了一下文章,發現好多人在討論這個問題,然後我又google了一下,發現微軟網站上也有類似的內容。

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

原因:

由於Asp.net程式是預設配置,所以Web.Config檔案中關於Session的設定如下:
<sessionState mode='InProc' stateConnectionString='tcpip=127.0.0.1:42424' sqlConnectionString='data source=127.0.0.1;Trusted_Connection=yes' cookieless='true' timeout='60'/>

我 們會發現sessionState標籤中有個屬性mode,它可以有3種取值:InProc、StateServer?SQLServer(大小寫敏 感) 。預設情況下是InProc,也就是將Session儲存在進程內(IIS5是aspnet_wp.exe,而IIS6是W3wp.exe),這個 進程不穩定,在某些事件發生時,進程會重起,所以造成了儲存在該進程內的Session丟失。

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

1、設定檔中processModel標籤的memoryLimit屬性
2、Global.asax或者Web.config檔案被更改
3、Bin檔案夾中的Web程式(DLL)被修改
4、殺毒軟體掃描了一些.config檔案。
更多的資訊請參考PRB: Session variables are lost intermittently in ASP.NET applications

解決辦法:

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

現在請將mode設定為StateServer。StateServer是原生一個服務,可以在系統服務裡看到服務名為ASP.NET State Service的服務,預設情況是不啟動的。當我們設定mode為StateServer之後,請手工將該服務啟動。

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

除 此之外,我們還可以將Session通過其他電腦的StateService來儲存。具體的修改是這樣的。同樣還在sessionState標籤中,有個 stateConnectionString='tcpip=127.0.0.1:42424'屬性,其中有個ip地址,預設為本機 (127.0.0.1),你可以將其改成你所知的運行了StateService服務的電腦IP,這樣就可以實現位於不同電腦上的Asp.net程式互連 Session了。

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

在使用StateServer或者SQLServer儲存Session時,所有需要儲存到Session的對象除了基礎資料型別 (Elementary Data Type)(預設的資料類型,如int、string等)外,都必須序列化。只需將[Serializable]標籤放到要序列化的類前就可以了。
如: 複製  儲存

< }

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

至此,問題解決。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.