Session丟失問題總結(jié)
當(dāng)前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
[p]最近在做asp.net項目時,測試網(wǎng)站老是取不出session中的值,在網(wǎng)上搜索了一下,找到一些解決方法,記錄在這里。最后使用存儲在stateserver中的辦法解決了問題。[br][/p]
[p]sessionstate 的timeout),其主要原因有三種。[br]一:有些殺病毒軟件會去掃描您的web.config文件,那時session肯定掉,這是微軟的說法。[br]二:程序內(nèi)部里有讓session掉失的代碼,及服務(wù)器內(nèi)存不足產(chǎn)生的。[br]三:程序有框架頁面和跨域情況。[br]第一種解決辦法是:使殺病毒軟件屏蔽掃描web.config文件(程序運行時自己也不要去編輯它)[br]第二種是檢查代碼有無session.abandon()之類的。[br]第三種是在window服務(wù)中將asp.net state service 啟動。[br][/p] [p]下面是幫助中的內(nèi)容:[br](ms-help://ms.vscc.2003/ms.msdnqtr.2003feb.2052/cpguide/html/cpconsessionstate.htm)[br]asp.net 提供一個簡單、易于使用的會話狀態(tài)模型,您可以使用該模型跨多個 web 請求存儲任意數(shù)據(jù)和對象。它使用基于字典的、內(nèi)存中的對象引用(這些對象引用存在于 iis 進程中)緩存來完成該操作。使用進程內(nèi)會話狀態(tài)模式時請考慮下面的限制: [/p] [p]使用進程內(nèi)會話狀態(tài)模式時,如果 aspnet_wp.exe 或應(yīng)用程序域重新啟動,則會話狀態(tài)數(shù)據(jù)將丟失。這些重新啟動通常會在下面的情況中發(fā)生: [br]在應(yīng)用程序的 web.config 文件的 還有這二種: [br][br]一:在第一個頁面置了session,然后redirect去第二個頁面。解決方法是在redirect中設(shè)置endresponse為false。 [br][br]二: asp.net中使用了access數(shù)據(jù)庫,而且數(shù)據(jù)庫是放在bin目錄中的。解決方法是不要放會更新的文件在bin目錄中。 Asp.net 默認配置下,Session莫名丟失的原因及解決辦法 正常操作情況下Session會無故丟失。因為程序是在不停的被操作,排除Session超時的可能。另外,Session超時時間被設(shè)定成60分鐘,不會這么快就超時的。 這次到CSDN上搜了一下帖子,發(fā)現(xiàn)好多人在討論這個問題,然后我又google了一下,發(fā)現(xiàn)微軟網(wǎng)站上也有類似的內(nèi)容。 現(xiàn)在我就把原因和解決辦法寫出來。 原因: 由于Asp.net程序是默認配置,所以Web.Config文件中關(guān)于Session的設(shè)定如下: 我們會發(fā)現(xiàn)sessionState標(biāo)簽中有個屬性mode,它可以有3種取值:InProc、StateServer?SQLServer(大小寫敏感) 。默認情況下是InProc,也就是將Session保存在進程內(nèi)(IIS5是aspnet_wp.exe,而IIS6是W3wp.exe),這個進程不穩(wěn)定,在某些事件發(fā)生時,進程會重起,所以造成了存儲在該進程內(nèi)的Session丟失。 哪些情況下該進程會重起呢?微軟的一篇文章告訴了我們: 1、配置文件中processModel標(biāo)簽的memoryLimit屬性 2、Global.asax或者Web.config文件被更改 3、Bin文件夾中的Web程序(DLL)被修改 4、殺毒軟件掃描了一些.config文件。 更多的信息請參考PRB: Session variables are lost intermittently in ASP.NET applications 解決辦法: 前面說到的sessionState標(biāo)簽中mode屬性可以有三個取值,除了InProc之外,還可以為StateServer、SQLServer。這兩種存Session的方法都是進程外的,所以當(dāng)aspnet_wp.exe重起的時候,不會影響到Session。 現(xiàn)在請將mode設(shè)定為StateServer。StateServer是本機的一個服務(wù),可以在系統(tǒng)服務(wù)里看到服務(wù)名為ASP.NET State Service的服務(wù),默認情況是不啟動的。當(dāng)我們設(shè)定mode為StateServer之后,請手工將該服務(wù)啟動。 這樣,我們就能利用本機的StateService來存儲Session了,除非電腦重啟或者StateService崩掉,否則Session是不會丟的(因Session超時被丟棄是正常的)。 除此之外,我們還可以將Session通過其他電腦的StateService來保存。具體的修改是這樣的。同樣還在sessionState標(biāo)簽中,有個stateConnectionString='tcpip=127.0.0.1:42424'屬性,其中有個ip地址,默認為本機(127.0.0.1),你可以將其改成你所知的運行了StateService服務(wù)的電腦IP,這樣就可以實現(xiàn)位于不同電腦上的Asp.net程序互通Session了。 如果你有更高的要求,需要在服務(wù)期重啟時Session也不丟失,可以考慮將mode設(shè)定成SQLServer,同樣需要修改sqlConnectionString屬性。關(guān)于使用SQLServer保存Session的操作,請訪問這里。 在使用StateServer或者SQLServer存儲Session時,所有需要保存到Session的對象除了基本數(shù)據(jù)類型(默認的數(shù)據(jù)類型,如int、string等)外,都必須序列化。只需將[Serializable]標(biāo)簽放到要序列化的類前就可以了。 如: [Serializable] public class MyClass { ...... } 具體的序列化相關(guān)的知識請參這里。 至此,問題解決。 該文章在 2010/6/26 1:42:45 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |