C# SESSION丟失問題的解決辦法。本站提示廣大學習愛好者:(C# SESSION丟失問題的解決辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是C# SESSION丟失問題的解決辦法正文
我們在用C#開發程序的時候經常會遇到Session很不穩定,老是數據丟失。下面就是Session數據丟失的解決辦法希望對您有好處。
1、在WEB.CONFIG文件中修改SESSION狀態保存模式,如:<sessionState mode='StateServer' stateConnectionString='tcpip=127.0.0.1:42424' sqlConnectionString='data source=127.0.0.1;Trusted_Connection=yes' cookieless='true' timeout='180'/>
2、啟動系統服務“ASP.NET狀態服務 ”,系統默認是手動啟動的
3、如果SESSION中保存的數據類型是自定義的,如結構,請在自定義數據類型處序列化會話狀態,即在類或結構申明前加[Serializable]
完成以上3部,狀態即可保存,但是在訪問頁面是浏覽器顯示的路徑中增加了一段字符,如:(S(lto3j0eg25cztmqtxevm5tb4))
最近在做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的對象除了基本數據類型(默認的數據類型,如int、string等)外,都必須序列化。只需將[Serializable]標簽放到要序列化的類前就可以了。
如:
[Serializable] public class MyClass ...... }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。