Asp.Net保存session的三種方法

C#中保存Session的三種方法及Web.Config設置

一、保存session到sql server,須要指定Sql Server服務器,這種方法由於要讀寫數據庫最慢sql

<sessionState
mode="SQLServer"
sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
cookieless="false"
timeout="20" />

二、 保存session到windows進程,要使用這種方法,須要打開aspnet_state.exe服務,經過此方法,咱們能夠將session保存到其它服務器,這樣能夠實現多臺服務器的session共享數據庫

<sessionState
mode="StateServer"
stateConnectionString="tcpip=127.0.0.1:42626"
cookieless="false"
timeout="20" />

三、默認狀況,.net將session保存到當前進程中,這種方式最快,可是不能多臺服務器共享sessionwindows

<sessionState
mode=」InProc」
cookieless=」false」
timeout=」20」
/>

課外閱讀瀏覽器

ASP.NET中客戶端Session狀態的存儲服務器

在咱們上面的Session模型簡介中,你們能夠發現Session狀態應該存儲在兩個地方,分別是客戶端和服務器端。客戶端只負責保存相應網站的SessionID,而其餘的Session信息則保存在服務器端。在ASP中,客戶端的SessionID實際是以Cookie的形式存儲的。若是用戶在瀏覽器的設置中選擇了禁用Cookie,那末他也就沒法享受Session的便利之處了,甚至形成不能訪問某些網站。爲了解決以上問題,在ASP.NET中客戶端的Session信息存儲方式分爲:Cookie和Cookieless兩種。cookie

ASP.NET中,默認狀態下,在客戶端仍是使用Cookie存儲Session信息的。若是咱們想在客戶端使用Cookieless的方式存儲Session信息的方法以下:session

找到當前Web應用程序的根目錄,打開Web.Config文件,找到以下段落:less

<sessionState
  mode="InProc"
  stateConnectionString="tcpip=127.0.0.1:42424"
  sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
  cookieless="false"
  timeout="20" 
/>tcp

 

這段話中的cookieless="false"改成:cookieless="true",這樣,客戶端的Session信息就再也不使用Cookie存儲了,而是將其經過URL存儲。關閉當前的IE,打開一個新IE,從新訪問剛纔的Web應用程序,就會看到相似下面的樣子:其中,http://localhost/MyTestApplication/(ulqsek45heu3ic2a5zgdl245)/default.aspx中黑體標出的就是客戶端的Session ID。注意,這段信息是由IIS自動加上的,不會影響之前正常的鏈接。網站

相關文章
相關標籤/搜索