自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

開發(fā) 后端
本文分析了ASP.NET Session丟失問題的原因及解決方案。asp的Session是具有進(jìn)程依賴性的。ASP Session狀態(tài)存于IIS的進(jìn)程中,也就是inetinfo.exe這個程序。

正常操作情況下會有ASP.NET Session丟失的情況出現(xiàn)。因為程序是在不停的被操作,排除Session超時的可能。另外,Session超時時間被設(shè)定成60分鐘,不會這么快就超時的。

現(xiàn)在我就把原因和解決辦法寫出來。

ASP.NET Session丟失原因:

由于Asp.net程序是默認(rèn)配置,所以Web.Config文件中關(guān)于Session的設(shè)定如下:

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

我們會發(fā)現(xiàn)sessionState標(biāo)簽中有個屬性mode,它可以有3種取值:InProc、StateServer?SQLServer(大小寫敏感) 。默認(rèn)情況下是InProc,也就是將Session保存在進(jìn)程內(nèi)(IIS5是aspnet_wp.exe,而IIS6是W3wp.exe),這個進(jìn)程不穩(wěn)定,在某些事件發(fā)生時,進(jìn)程會重起,所以造成了存儲在該進(jìn)程內(nèi)的Session丟失。

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

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

ASP.NET Session丟失解決辦法:

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

現(xiàn)在請將mode設(shè)定為StateServer。StateServer是本機(jī)的一個服務(wù),可以在系統(tǒng)服務(wù)里看到服務(wù)名為ASP.NET State Service的服務(wù),默認(rèn)情況是不啟動的。當(dāng)我們設(shè)定mode為StateServer之后,請手工將該服務(wù)啟動。

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

除此之外,我們還可以將Session通過其他電腦的StateService來保存。具體的修改是這樣的。同樣還在sessionState標(biāo)簽中,有個stateConnectionString='tcpip=127.0.0.1:42424'屬性,其中有個ip地址,默認(rèn)為本機(jī)(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ù)類型(默認(rèn)的數(shù)據(jù)類型,如int、string等)外,都必須序列化。只需將[Serializable]標(biāo)簽放到要序列化的類前就可以了。

如:

[Serializable]

public class MyClass

{

    ......

}

具體的序列化相關(guān)的知識請參這里。

至此,ASP.NET Session丟失問題解決。

關(guān)于asp.net Session丟失問題的總結(jié)

asp中Session的工作原理:

asp的Session是具有進(jìn)程依賴性的。ASP Session狀態(tài)存于IIS的進(jìn)程中,也就是inetinfo.exe這個程序。所以當(dāng)inetinfo.exe進(jìn)程崩潰時,這些信息也就丟失。另外,重起或者關(guān)閉IIS服務(wù)都會造成信息的丟失。

asp.net Session的實現(xiàn)

asp.net的Session是基于HttpModule技術(shù)做的,HttpModule可以在請求被處理之前,對請求進(jìn)行狀態(tài)控制,由于Session本身就是用來做狀態(tài)維護(hù)的,因此用HttpModule做Session是再合適不過了。

原因1:

bin目錄中的文件被改寫,asp.net有一種機(jī)制,為了保證dll重新編譯之后,系統(tǒng)正常運行,它會重新啟動一次網(wǎng)站進(jìn)程,這時就會導(dǎo)致Session丟失,所以如果有access數(shù)據(jù)庫位于bin目錄,或者有其他文件被系統(tǒng)改寫,就會導(dǎo)致Session丟失

原因2:

文件夾選項中,如果沒有打開“在單獨的進(jìn)程中打開文件夾窗口”,一旦新建一個窗口,系統(tǒng)可能認(rèn)為是新的Session會話,而無法訪問原來的Session,所以需要打開該選項,否則會導(dǎo)致Session丟失

原因3:

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

原因4:

Session的時間設(shè)置是不是有問題,會不會因為超時造成丟失

原因5:

IE中的cookie數(shù)量限制(每個域20個cookie)可能導(dǎo)致session丟失

原因6:

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

ASP.NET Session丟失問題解決經(jīng)驗

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

2. 做Session讀寫日志,每次讀寫Session都要記錄下來,并且要記錄SessionID、Session值、所在頁面、當(dāng)前函數(shù)、函數(shù)中的第幾次Session操作,這樣找丟失的原因會方便很多

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

4. 在global.asa中加入代碼記錄Session的創(chuàng)建時間和結(jié)束時間,超時造成的Session丟失是可以在SessionEnd中記錄下來的。

5. 如果有些代碼中使用客戶端腳本,如javascript維護(hù)Session狀態(tài),就要嘗試調(diào)試腳本,是不是因為腳本錯誤引起Session丟失

【編輯推薦】

  1. ASP.NET的代碼隱藏文件
  2. 淺談ASP.NET MVC框架
  3. 介紹ASP.NET MVC中的MvcAjaxPanel
  4. ASP.NET MVC框架拯救UpdatePanel
  5. 用ASP.NET MVC源代碼尋找解決方案
責(zé)任編輯:yangsai 來源: 163博客
相關(guān)推薦

2010-09-02 15:18:42

CSSASP.NET

2009-07-23 16:53:17

ASP.NET中文變問

2009-07-22 18:02:26

ASP.NET Ses

2009-07-24 11:24:33

ASP.NET中文亂碼

2009-07-28 16:57:50

ASP.NET Ses

2009-07-22 11:00:30

ASP.NET MVC

2012-01-11 10:55:02

ASP.NET MVC

2014-12-11 10:05:13

ASP.NET

2009-07-22 17:50:14

2009-07-28 12:30:53

ASP.NET畫面跳轉(zhuǎn)

2009-07-29 10:19:48

Session StaASP.NET

2009-08-03 10:07:20

ASP.NET Ses

2009-07-23 18:56:50

ASP.NET Ses

2009-07-30 16:02:53

2009-07-28 12:35:37

querystring

2009-07-24 10:41:00

ASP.NET Ses

2009-07-20 17:21:43

Session狀態(tài)ASP.NET

2010-06-04 19:06:47

連接MySQL數(shù)據(jù)庫

2018-10-12 14:34:13

2009-07-10 09:39:25

ASP.NET網(wǎng)站性能
點贊
收藏

51CTO技術(shù)棧公眾號