ASP.NET Session對象保持會話使用說明
更新時間:2012年12月16日 13:56:03 作者:
ASP.NET提供了Session對象,從而允許程序員識別、存儲和處理同一個瀏覽器對象對服務(wù)器上某個特定網(wǎng)絡(luò)應(yīng)用程序的若干次請求的上下文信息
ASP.NET提供了Session對象,從而允許程序員識別、存儲和處理同一個瀏覽器對象對服務(wù)器上某個特定網(wǎng)絡(luò)應(yīng)用程序的若干次請求的上下文信息。Session對應(yīng)瀏覽器與服務(wù)器的同一次對話,在瀏覽器第一請求網(wǎng)絡(luò)應(yīng)用程序的某個頁面時,服務(wù)器會觸發(fā)Session_onStart事件;在對話超時或者被關(guān)閉的時候會觸發(fā)Session_onEnd事件。程序員可以在代碼中響應(yīng)這兩個事件來處理與同一次對話相關(guān)的任務(wù),如開辟和釋放該次對話要使用的資源等。
在ASP.NET的程序中要使用Session對象時,必須確保頁面的@page指令中EnableSessionState屬性是True或者Readonly,并且在web.config文件中正確的設(shè)置了SessionState屬性。
ASP.NET中Session的狀態(tài)保持是由web.config文件中的<system.web>標記下的<sessionstate>標記的mode屬性來決定的。該屬性有四種可能的值:Off、Inproc、StateServer和SQlServer.
設(shè)為Off會禁用Session.
Inproc是缺省的設(shè)置,這種模式和以前的ASP的會話狀態(tài)的方法是類似的,會話的狀態(tài)會被保存在ASP.NET進程中,它的優(yōu)點是顯而易見的:性能。進程內(nèi)的數(shù)據(jù)訪問自然會比夸進程的訪問快。然而,這種方法Session的狀態(tài)依賴于ASP.NET進程,當IIS進程崩潰或者正常重起啟時,保存在進程中的狀態(tài)將丟失。
為了克服Inproc模式的缺點,ASP.NET提供了兩種進程外保持會話狀態(tài)的方法。
ASP.NET首先提供了提供了一個Windows服務(wù):ASPState,這個服務(wù)啟動后,ASP.NET應(yīng)用程序可以將mode屬性設(shè)置為“SateServer”,來使用這個Windows服務(wù)提供的狀態(tài)管理方法。
除了在web.config文件中設(shè)置mode屬性為StateServer外,還必須設(shè)置運行StateServer服務(wù)器的IP地址和端口號.如果在IIS所在的機器運行StateServer則IP地址就是127.0.0.1,端口號通常是42424.配置如下:
mode=”StateServer”
stateConnectionString="tcpip=127.0.0.1:42424"
使用這種模式,會話狀態(tài)的存儲將不依賴IIS進程的失敗或者重啟,會話的狀態(tài)將存儲在StateServer進程的內(nèi)存空間中。
另一種會話狀態(tài)模式是SQLServer模式。這種模式是將會話的狀態(tài)保存在SQLServer數(shù)據(jù)庫中的。使用這種模式前,必須至少有一臺SQLServer服務(wù)器,并在服務(wù)器中建立需要的表和存儲過程。.NETSDK提供了兩個腳本來簡化這個工作:InstallSqlState.sql和UnInstallSqlState.sql。這兩國文件存放在下面路徑中:
<%SYSTEMDRIVER%>\Winnt\Microsoft.NET\Framework\<%version%>\
要配置SQLServer服務(wù)器,可以在命令行中運行SQLServer提供的命令行工具osql.exe
osql-s[servername]-u[user]-p[password]<InstallSqlState.sql
例如:
osql-s(local)-uas-p“”-iInstallSqlState.sql
做好必要的數(shù)據(jù)庫準備工作后,將web.config文件中的sessionstate元素的mode屬性改為”sqlserver”,并指定SQL連接字符串。具體如下:
mode="SQLServer"
sqlConnectionString="datasource=127.0.0.1;userid=sa;password=;Trusted_Connection=yes"
使用SQLServer模式處了可以使Session的狀態(tài)不依賴于IIS服務(wù)器之外,還可以利用SQLServer的集群,使狀態(tài)存儲不依賴于單個的SQLServer,這樣就可以為應(yīng)用程序提供極大的可靠性。
總結(jié):seesion通過兩種方式保持會話,cookie/存儲到數(shù)據(jù)中去
在ASP.NET的程序中要使用Session對象時,必須確保頁面的@page指令中EnableSessionState屬性是True或者Readonly,并且在web.config文件中正確的設(shè)置了SessionState屬性。
ASP.NET中Session的狀態(tài)保持是由web.config文件中的<system.web>標記下的<sessionstate>標記的mode屬性來決定的。該屬性有四種可能的值:Off、Inproc、StateServer和SQlServer.
設(shè)為Off會禁用Session.
Inproc是缺省的設(shè)置,這種模式和以前的ASP的會話狀態(tài)的方法是類似的,會話的狀態(tài)會被保存在ASP.NET進程中,它的優(yōu)點是顯而易見的:性能。進程內(nèi)的數(shù)據(jù)訪問自然會比夸進程的訪問快。然而,這種方法Session的狀態(tài)依賴于ASP.NET進程,當IIS進程崩潰或者正常重起啟時,保存在進程中的狀態(tài)將丟失。
為了克服Inproc模式的缺點,ASP.NET提供了兩種進程外保持會話狀態(tài)的方法。
ASP.NET首先提供了提供了一個Windows服務(wù):ASPState,這個服務(wù)啟動后,ASP.NET應(yīng)用程序可以將mode屬性設(shè)置為“SateServer”,來使用這個Windows服務(wù)提供的狀態(tài)管理方法。
除了在web.config文件中設(shè)置mode屬性為StateServer外,還必須設(shè)置運行StateServer服務(wù)器的IP地址和端口號.如果在IIS所在的機器運行StateServer則IP地址就是127.0.0.1,端口號通常是42424.配置如下:
mode=”StateServer”
stateConnectionString="tcpip=127.0.0.1:42424"
使用這種模式,會話狀態(tài)的存儲將不依賴IIS進程的失敗或者重啟,會話的狀態(tài)將存儲在StateServer進程的內(nèi)存空間中。
另一種會話狀態(tài)模式是SQLServer模式。這種模式是將會話的狀態(tài)保存在SQLServer數(shù)據(jù)庫中的。使用這種模式前,必須至少有一臺SQLServer服務(wù)器,并在服務(wù)器中建立需要的表和存儲過程。.NETSDK提供了兩個腳本來簡化這個工作:InstallSqlState.sql和UnInstallSqlState.sql。這兩國文件存放在下面路徑中:
<%SYSTEMDRIVER%>\Winnt\Microsoft.NET\Framework\<%version%>\
要配置SQLServer服務(wù)器,可以在命令行中運行SQLServer提供的命令行工具osql.exe
osql-s[servername]-u[user]-p[password]<InstallSqlState.sql
例如:
osql-s(local)-uas-p“”-iInstallSqlState.sql
做好必要的數(shù)據(jù)庫準備工作后,將web.config文件中的sessionstate元素的mode屬性改為”sqlserver”,并指定SQL連接字符串。具體如下:
mode="SQLServer"
sqlConnectionString="datasource=127.0.0.1;userid=sa;password=;Trusted_Connection=yes"
使用SQLServer模式處了可以使Session的狀態(tài)不依賴于IIS服務(wù)器之外,還可以利用SQLServer的集群,使狀態(tài)存儲不依賴于單個的SQLServer,這樣就可以為應(yīng)用程序提供極大的可靠性。
總結(jié):seesion通過兩種方式保持會話,cookie/存儲到數(shù)據(jù)中去
相關(guān)文章
ASP.NET Core中如何使用表達式樹創(chuàng)建URL詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core中如何使用表達式樹創(chuàng)建URL的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2018-10-10Asp.Net二級域名共享Forms身份驗證、下載站/圖片站的授權(quán)訪問控制
我們平時一般在做圖片或者文件下載權(quán)限控制的時候基本都是控制到下載頁面的,當你的下載地址暴露后,瀏覽者就直接可以通過文件地址進行下載了,這時候也就出現(xiàn)了我們常說的盜鏈2012-02-02ASP.NET(VB)寫的后臺發(fā)送短信實現(xiàn)代碼
使用vb寫的后臺發(fā)送短信代碼,很實用的一項功能,感興趣的朋友可以了解下,或許對你學(xué)習asp.net vb有所幫助2013-02-02在應(yīng)用程序級別之外使用注冊為allowDefinition=''MachineToApplication''的節(jié)是錯誤的
在應(yīng)用程序級別之外使用注冊為 allowDefinition='MachineToApplication' 的節(jié)是錯誤的2009-03-03Repeater綁定dictionary數(shù)據(jù)源代碼及報錯解決
為大家講解下Repeater綁定dictionary數(shù)據(jù)源以及報錯處理的方法,感興趣的朋友可以參考下哈,希望對你有所幫助2013-04-04根據(jù)Eval()函數(shù)綁定的值,來顯示GridView中的控件的方法
根據(jù)Eval()函數(shù)綁定的值,來顯示GridView中的控件的方法,需要的朋友可以參考一下2013-03-03