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

詳解ASP.NET在不同的子域中共享Session

原創(chuàng)
開發(fā) 后端
本文將研究的是ASP.NET在不同的子域中共享Session,包括Session的機理以及相關作用。希望對大家有所幫助。

今天遇到了這個問題,于是研究了一下。要解決這個問題,首先就要明白一些Session的機理。Session在服務器是以散列表形式存在的,我們都知道Session是會話級的,每個用戶訪問都會生成一個Session。那么服務器是怎么區(qū)分不同用戶的Session?又是怎么將不同用戶的Session與不同的用戶綁定的呢?下面我們來研究一下,以下純屬我個人的理解,如有錯誤請指證。

Session在服務器端是以散列表的形式存在的,區(qū)分每一個Session是通過SessionID來實現(xiàn)的,所以可以說這個SessionID是一個Key是一個全局唯一的值。我們可以通過ASP.NET來打印出SessionID,如下代碼:

  1. protected void Page_Load(object sender, EventArgs e)  
  2.         {  
  3.   Response.Write(Session.SessionID.ToString());  
  4.         } 

這樣我們就得到了這樣的值:0julmoedn0kz3gyfnr1vksv0,有點像是GUID,就算不是算法也都是類似的,主要就是為了保證全局唯一性。這樣就達到了區(qū)分不同用戶的Session的目的。接下來還有第二個問題,那就是SessionID有了,但是它又是怎么和相應的訪問者(用戶)綁定的呢?比如說用戶A訪問維護了自己的SessionID,用戶B訪問也維護了自己的SessionID。我們都知道web是基于http無鏈接的,他們又是怎么做到的呢?沒錯,答案就是在客戶端存儲了自己的SessionID。瀏覽器存儲SessionID有兩種方式,一種就是利用Cookies;還有一種就是利用url參數(shù)(這種我們不常用,很不友好)。

話題說到Cookies上來了,怎么的?沒想到Session和Cookies還有這樣的關系吧?(很多人知道,別BS我)沒錯,當我們請求一個URL時候,服務器會生成一個全局的SessionID,并且把這個值以Cookies的形式保存在客戶端也就是瀏覽器(這里暫不討論url方式)。這樣當用戶再去請求的時候,在http頭把這個SessionID的Cookie發(fā)到服務器端,服務器就去找這個SessionID,如果找到了。就證明這個用戶的狀態(tài)是存在的。

知道了這個原理,我們的問題也就有眉頭了,即然是用Cookies來保存SessionID,那么我們就可以在Cooikes上做手腳了。我們都知道Cooikes記錄方式是以域(例如:http://www.local.com/)為區(qū)分的,這也是各種瀏覽器規(guī)定的。如果不這么做,安全性就會有問題。我們要做的就是讓指定Cookies的父域方式,不指定具體指域,這樣Cookies就可以跨子域了。Cookies可以像這樣指定域:

  1. protected void Page_Load(object sender, EventArgs e)  
  2.        {  
  3. Response.Cookies["MyCook"].Domain = ".local.com";  
  4.        } 

這樣,我們所有的二級域全部是認這一個主域的,比如a.local.com;b.local.com;user.local.com等等。有了這個認識,我想大家心里也有數(shù)了,該怎么怎么做,但是現(xiàn)在問題是用來生成SessionID的方法是ASP.NET自動實現(xiàn)的,我們又怎么去干涉它呢?這是這樣做的,不主動干涉它,但是我可以操作它的Cookies啊。接下來我們就研究ASP.NET存SessionID的Cooike的名字是什么。經(jīng)過網(wǎng)上很容易就查找到了,名字是:ASP.NET_SessionId,這個就是SessionId的Cookies名字。我們可以在Session_Start中這樣寫:

  1.  protected void Session_Start(object sender, EventArgs e)  
  2.         {  
  3. Response.Cookies["ASP.NET_SessionId"].Value = Session.SessionID.ToString();  
  4.  Response.Cookies["ASP.NET_SessionId"].Domain = ".local.com";  
  5.         }  

代碼的意思是每次會話開始的時候,我都把ASP.NET_SessionId這個Cookie重寫成我們已有的SessionID,并且把這個Cookie的domain指定為父域,比如:.local.com,這樣就可以實現(xiàn)跨子域的Session共享了。怎么樣很簡單吧?

我們還有一個外題問題,就是客戶端保存的問題解決了,但是服務器端的Session怎么辦?一般情況下我們不同的子域做的是指向不同的服務器的,比如user.local.com 專門一臺服務器,yellow.local.com專門一臺服務器。這時它們別說是進程了,連物理上都不是一個了。Session怎么共享?這時就用到另一個方法了,我們默認的Session是存儲在asp.net進程中的,這樣沒法互相訪問,如下面所示:

  1. <sessionState mode="InProc" /> 

我們可以修改為State Server方式,這是一個單獨的服務可以用來存儲ASP.NET Session的,它支持分布式遠程主機的,這樣我們可以用一臺服務器來提供Session服務,如下所示:

  1. <sessionState mode="StateServer" stateConnectionString
  2. ="tcpip=127.0.0.1:42424" timeout="30" /> 

這樣,就完全實現(xiàn)了不同子域的Session共享了。

前面說到Url保存SessionId的方式,由于不常用,給大家演示一下,如下配置就可以了:

  1. <sessionState mode="StateServer" stateConnectionString=
  2. "tcpip=127.0.0.1:42424" timeout="30" cookieless="true" /> 

cookieless屬性指定是否用cookie來保存SessionId,我們運行一下得到下面的樣子:

http://localhost:3380/(S(dqxcs455n4u2vg55ia51fvqg))/default.aspx

原文標題:ASP.NET中在不同的子域中共享Session

鏈接:http://www.cnblogs.com/assion/archive/2010/07/29/1787960.html

【編輯推薦】

  1. 添加設置ASP.NET Web時出現(xiàn)問題
  2. 詳細說明ASP.NET 2.0功能支持
  3. 強化部署ASP.Net 2.0配置應用程序
  4. 微軟PDC2009直擊:改進ASP.NET 4運行時
  5. 詳解ASP.NET MVC 2自定義驗證

 

責任編輯:彭凡 來源: 博客園
相關推薦

2009-07-28 16:57:50

ASP.NET Ses

2009-07-02 14:39:27

Session的值JSP Asp.net

2009-07-07 12:34:54

Servlet在ses

2009-07-29 10:19:48

Session StaASP.NET

2009-07-23 18:56:50

ASP.NET Ses

2009-07-24 10:41:00

ASP.NET Ses

2009-07-20 17:21:43

Session狀態(tài)ASP.NET

2009-08-03 10:07:20

ASP.NET Ses

2009-07-29 16:08:07

ASP和ASP.NET

2009-07-23 13:19:51

2009-08-05 18:30:36

Session和CooASP.NET表單

2009-07-24 10:41:00

ASP.NET Ses

2009-07-24 10:14:22

ASP.NET開發(fā)

2009-08-05 11:14:33

ASP.NET ISA

2009-07-22 16:25:41

ASP.NET AJA

2009-07-22 18:02:26

ASP.NET Ses

2009-03-13 09:48:33

ASP.NETAjaxJQuery

2009-03-31 09:18:34

客戶端內置對象ASP.NET

2009-07-28 13:39:44

加載ViewStateASP.NET

2009-08-04 10:43:59

ASP.NET控件開發(fā)
點贊
收藏

51CTO技術棧公眾號