隨筆-208  評論-469  文章-30  trackbacks-0

          Session模型簡介

          Session 是什么呢?簡單來說就是服務器給客戶端的一個編號。當一臺WWW服務器運行時,可能有若干個用戶瀏覽正在運正在這臺服務器上的網站。當每個用戶首次與這臺WWW服務器建立連接時,他就與這個服務器建立了一個Session,同時服務器會自動為其分配一個SessionID,用以標識這個用戶的唯一身份。這個SessionID是由WWW服務器隨機產生的一個由24個字符組成的字符串,我們會在下面的實驗中見到它的實際樣子。

          這個唯一的SessionID是有很大的實際意義的。當一個用戶提交了表單時,瀏覽器會將用戶的SessionID自動附加在HTTP頭信息中,(這是瀏覽器的自動功能,用戶不會察覺到),當服務器處理完這個表單后,將結果返回給SessionID所對應的用戶。試想,如果沒有SessionID,當有兩個用戶同時進行注冊時,服務器怎樣才能知道到底是哪個用戶提交了哪個表單呢。當然,SessionID還有很多其他的作用,我們會在后面提及到。

          除了SessionID,在每個Session中還包含很多其他信息。但是對于編寫ASPASP.NET的程序與來說,最有用的還是可以通過訪問ASP/ASP.NET的內置Session對象,為每個用戶存儲各自的信息。例如我們想了解一下訪問我們網站的用戶瀏覽了幾個頁面,我們可能在用戶可能訪問到每個的頁面中加入:

          <%
          If Session("PageViewed") = ""Then
            Session("PageViewed") = 1
          Else
           
          Session("PageViewed") = Session("PageViewed") + 1
          End If
          %>

          通過以下這句話可以讓用戶得知自己瀏覽了幾個頁面:

          <%
          Response.Write("You have viewed " & Session("PageViewed") & " pages")
          %>

          可能有些有些讀者會問:這個看似像是數組的Session(..)是哪里來的?需要我定義嗎?實際上,這個Session對象是具有ASP解釋能力的的WWW服務器的內建對象。也就是說ASP的系統中已經給你定義好了這個對象,你只需要使用就行了。其中Session(..)中的..就好像變量名稱,Session(..)=$$$中的$$$就是變量的值了。你只需要寫上句話,在這個用戶的每個頁面中都可以訪問..變量中的值了。

          其實ASP一共內建了7個對象,有SessionApplicationCookieResponseRequestServer等。在其他的服務器端腳本語言如JSPPHP等中也有其類似的對象,只是叫法或者使用方法上不太一樣。

          ASP Session的功能的缺陷

          目前ASP的開發人員都正在使用Session這一強大的功能,但是在他們使用的過程中卻發現了ASP Session有以下缺陷:

          • 進程依賴性:ASP Session狀態存于IIS的進程中,也就是inetinfo.exe這個程序。所以當inetinfo.exe進程崩潰時,這些信息也就丟失。另外,重起或者關閉IIS服務都會造成信息的丟失。
          • Session 狀態使用范圍的局限性:剛一個用戶從一個網站訪問到另外一個網站時,這些Session信息并不會隨之遷移過去。例如:新浪網站的WWW服務器可能不止一個,一個用戶登錄之后要去各個頻道瀏覽,但是每個頻道都在不同的服務器上,如果想在這些WWW服務器共享Session信息怎么辦呢?
          • Cookie 的依賴性:實際上客戶端的Session信息是存儲與Cookie中的,如果客戶端完全禁用掉了Cookie功能,他也就不能享受到了Session提供的功能了。

          鑒于ASP Session的以上缺陷,微軟的設計者們在設計開發 ASP.NET Session時進行了相應的改進,完全克服了以上缺陷,使得ASP.NET Session成為了一個更加強大的功能。

          Web.config文件簡介

          有的ASP.NET程序員說:Web.config文件?我從來沒有聽說過啊,可是我寫的程序不是也能很正常的運轉嗎?是的,你說得沒錯,沒有Web.config文件程序是可以正常運行的。但是,如果你做了一個大型的網站,需要對整個網站做一些整體配置,例如整個網站的頁面使用何種語言編寫的、網站的安全認證模式、Session信息存儲方式等,這時你就需要使用Web.config文件了。雖然Web.config文件中的某些選項是可以通過IIS配置的,但是如果在Web.config中也有相應的設置就會覆蓋掉IIS中的配置。而且,Web.config文件的最大的便利之處就是可以在ASP.NET頁面中通過調用System.web名字空間訪問Web.config中的設置。

          Web.config 有兩種,分別是服務器配置文件和Web應用程序配置文件,他們都名為Web.config。在這個配置文件中會保存當前IIS服務器中網頁的使用哪種語言編寫的、應用程序安全認證模式、Session信息存儲方式的一系列信息。這些信息是使用XML語法保存的,如果想對其編輯,使用文本編輯器就行了。

          其中服務器配置文件會對IIS服務器下所有的站點中的所有應用程序起作用。在.NET Framework 1.0中,服務器的Web.config文件是存在:\WinNT\Microsoft.NET\Framework\v1.0.3705中的。

          Web應用程序配置文件Web.config則保存在各個Web應用程序中。例如:當前網站的根目錄\Inetpub\wwwroot,而當前的Web應用程序為MyApplication,則Web應用程序根目錄就應為:\Inetpub\wwwroot\MyApplication。如果你的網站有且只有一個Web應用程序,一般說來應用程序的根目錄就是\Inetpub\wwwroot。如果想添加一個Web應用程序,在IIS中添加一個具有應用程序起始點的虛擬目錄就行了。這個目錄下的文件及目錄將被視為一個Web應用程序。但是,這樣通過IIS添加Web應用程序是不會為你生成Web.config文件的。如果想創建一個帶有Web.config文件的Web應用程序,需要使用Visual Studio.NET,新建一個Web應用程序項目。

          Web 應用程序的配置文件Web.config是可選的,可有可無。如果沒有,每個Web應用程序會使用服務器的Web.config配置文件。如果有,則會覆蓋服務器Web.config配置文件中相應的值。

          ASP.NET中,Web.config修改保存后會自動立刻成效,不用再像ASP中的配置文件修改后需要重新啟動Web應用程序才能生效了。

          Web.config文件中的Session配置信息

          打開某個應用程序的配置文件Web.config后,我們會發現以下這段:

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

          這一段就是配置應用程序是如何存儲Session信息的了。我們以下的各種操作主要是針對這一段配置展開。讓我們先看看這一段配置中所包含的內容的意思。sessionState節點的語法是這樣的:

          				
          						<sessionState
          				
          				
          						mode="Off|InProc|StateServer|SQLServer"
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						
          								????????????? cookieless
          				
          				="true|false"
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						
          								????????????? timeout
          				
          				="number of minutes"
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						
          								????????????? stateConnectionString
          				
          				="tcpip=server:port"
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						
          								????????????? sqlConnectionString
          				
          				="sql connection string"
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						
          								????????????? stateNetworkTimeout=
          				
          				
          						"number of seconds"
          				
          				
          						
          						
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						?
          				
          		
          				
          						/>
          				
          				
          						
          						
          				
          		

          必須有的屬性是

          屬性選項 描述 mode設置將Session信息存儲到哪里 Off設置為不使用Session功能 InProc設置為將Session存儲在進程內,就是ASP中的存儲方式,這是默認值。 StateServer設置為將Session存儲在獨立的狀態服務中。 SQLServer設置將Session存儲在SQL Server中。

          可選的屬性是:

          屬性選項 描述 cookieless設置客戶端的Session信息存儲到哪里 ture使用Cookieless模式 false使用Cookie模式,這是默認值。 timeout設置經過多少分鐘后服務器自動放棄Session信息。默認為20分鐘 stateConnectionString設置將Session信息存儲在狀態服務中時使用的服務器名稱和端口號,例如:"tcpip=127.0.0.1:42424”。當mode的值是StateServer是,這個屬性是必需的。 sqlConnectionString設置與SQL Server連接時的連接字符串。例如"data source=localhost;Integrated Security=SSPI;Initial Catalog=northwind"。當mode的值是SQLServer時,這個屬性是必需的。 stateNetworkTimeout設置當使用StateServer模式存儲Session狀態時,經過多少秒空閑后,斷開Web服務器與存儲狀態信息的服務器的TCP/IP連接的。默認值是10秒鐘。

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

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

          ASP.NET 中,默認狀態下,在客戶端還是使用Cookie存儲Session信息的。如果我們想在客戶端使用Cookieless的方式存儲Session信息的方法如下:

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

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

          這段話中的cookieless="false"改為:cookieless="true",這樣,客戶端的Session信息就不再使用Cookie存儲了,而是將其通過URL存儲。關閉當前的IE,打開一個新IE,重新訪問剛才的Web應用程序,就會看到類似下面的樣子:

          ?

          其中,http://localhost/MyTestApplication/(ulqsek45heu3ic2a5zgdl245)/default.aspx中黑體標出的就是客戶端的Session ID。注意,這段信息是由IIS自動加上的,不會影響以前正常的連接。

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

          準備工作

          為了您能更好的體驗到實驗現象,您可以建立一個叫做SessionState.aspx的頁面,然后把以下這些代碼添加到<body></body>中。

          < script runat ="server">
          Sub Session_Add(sender As Object, e As EventArgs)
            ? Session("MySession") = text1.Value
           
          ? span1.InnerHtml = "Session data updated! <P>Your session contains: <font color=red>" & \
                    
          ? Session("MySession").ToString() & "</font>"
          End Sub

          Sub
          CheckSession(sender As Object, eAs EventArgs)
           ? If (Session("MySession")Is Nothing) Then
             
          span1.InnerHtml = "NOTHING, SESSION DATA LOST!"
           ? Else

              span1.InnerHtml = "Your session contains: <font color=red>" & \
                      
          Session("MySession").ToString() & "</font>"
          End If
          End Sub

          </ script >
          < form runat ="server" id ="Form2">
           ? < input id ="text1" type ="text" runat ="server" name ="text1">
           ? < input type ="submit" runat ="server" OnServerClick ="Session_Add"
                value ="Add to Session State" id ="Submit1" name ="Submit1">
           ? < input type ="submit" </p

          posted on 2006-11-30 08:52 EricWong 閱讀(432) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 大悟县| 盘锦市| 东宁县| 镶黄旗| 扎囊县| 崇左市| 台江县| 珠海市| 蒙山县| 凯里市| 菏泽市| 铁岭市| 镇康县| 成武县| 洛南县| 栖霞市| 彩票| 乐昌市| 连南| 公主岭市| 马边| 阿巴嘎旗| 阳山县| 蒲城县| 延边| 阳城县| 青田县| 临武县| 铜川市| 嘉义县| 柳林县| 五家渠市| 马边| 凯里市| 江永县| 泰宁县| 曲周县| 楚雄市| 宁国市| 晋城| 新野县|