佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > asp.net配置會話狀態(tài)Session實現(xiàn)代碼

asp.net配置會話狀態(tài)Session實現(xiàn)代碼

熱門標(biāo)簽:Mysql連接數(shù)設(shè)置 阿里云 科大訊飛語音識別系統(tǒng) 團(tuán)購網(wǎng)站 銀行業(yè)務(wù) Linux服務(wù)器 電子圍欄 服務(wù)器配置
下面來詳細(xì)說明:

復(fù)制代碼 代碼如下:

sessionState
timeout="timeout in minutes"
cookieless="[true|false]"
mode="Off|InProc|StateServer|SQLServer"
stateConnectionString="tcpip=server:port"
stateNetworkTimeout="for network operations with State Server,in seconds"
sqlConnectionString="valid SqlConnection string,minus Initial Catalog"
/>

timeout:指定了活動結(jié)束后會話的生存期(以分鐘計算)。如果用戶在一段指定的時間內(nèi)沒有被激活,就會有一個新的會話被創(chuàng)建,而先前的狀態(tài)將全部丟失。
cookieless:在默認(rèn)狀態(tài)下,所生成的會話ID被存儲在一個cookie中,稍后,這個cookie會在其他請求中被ASP.NET讀取,以便對會話狀態(tài)進(jìn)行判斷,從而連接到當(dāng)前用戶。
如果有些用戶禁用了瀏覽器中的cookie,我們就可以通過cookieless為這些用戶起用會話狀態(tài)。當(dāng)設(shè)置為true時,ASP.NET會自動把會話ID追加到URL,以及存在于被請求頁面中的任何相關(guān)的URL。

沒有啟用,設(shè)置為false
啟用,設(shè)置為true


這個機(jī)制會增加一個處理步驟,因為頁面中所有的鏈接都必須進(jìn)行重寫才能包含這個會話ID,以后所請求的URL必須經(jīng)過解析才能提取它并獲取實際的資源URL(沒有會話ID)。
mode:狀態(tài)模式。

InProc——這是一個默認(rèn)設(shè)置。所有的狀態(tài)都保存在運(yùn)行應(yīng)用程序的同一個進(jìn)程的內(nèi)存中。這樣能夠使性能達(dá)到最優(yōu),但是如果應(yīng)用程序被重啟,或者進(jìn)程由于某種原因而被掛起,那么相關(guān)用戶的所有會話數(shù)據(jù)都將丟失。

StateServer——可以利用這個設(shè)置從運(yùn)行應(yīng)用程序的進(jìn)程中分離出狀態(tài)存儲器。它可以聯(lián)合下面兩個屬性:
stateConnectionString="tcpip=server:port" stateNetworkTimeout="for network operations with State Server,in seconds"

可以通過指定機(jī)器的地址和端口,把狀態(tài)信息保存到它自己的進(jìn)程和內(nèi)存中。這樣可以把狀態(tài)從應(yīng)用程序中隔離出來,防止它出現(xiàn)故障。在狀態(tài)服務(wù)器及其中,必須啟動ASP.NET狀態(tài)服務(wù),這項服務(wù)的啟動既可以通過Serivces控制臺完成,也可以通過下面的命令提示完成:

>net start aspnet_state

還可以把這項服務(wù)設(shè)置為自動啟動。通過設(shè)置好狀態(tài)服務(wù)器的IP地址,就可以把相應(yīng)的機(jī)器指定為保存應(yīng)用程序的狀態(tài)信息。這樣可以防止應(yīng)用程序服務(wù)器重啟,但是卻不能防止機(jī)器重新啟動。還需要注意的是,把狀態(tài)存儲器放在應(yīng)用進(jìn)程外面會產(chǎn)生性能沖突,特別是當(dāng)應(yīng)用程序位于網(wǎng)絡(luò)中的另一臺機(jī)器上時。一定要弄清楚保留會話信息所引起的沖突是否是正常的。

SQLServer——如果決定不惜任何代價保留會話狀態(tài),就可以利用這個設(shè)置。這個模式可以把所有會話狀態(tài)保存在SQL Server數(shù)據(jù)庫中,因此它可以經(jīng)受應(yīng)用程序、服務(wù)器、甚至數(shù)據(jù)庫服務(wù)器(假設(shè)數(shù)據(jù)庫本身無故障)的任何失敗操作。對這個模式進(jìn)行設(shè)置其實就是對sessionState元素的以下屬性進(jìn)行配置:

sqlConnectionString="valid SqlConnection string,minus Initial Catalog"
還必須運(yùn)行一個腳本,準(zhǔn)備存儲狀態(tài)所需的數(shù)據(jù)庫。腳本在D:\WINDOWS\Microsoft.NET\Framework\v1.1.4322路徑下的installsqlstate.sql文件

運(yùn)行這個腳本不需要使用SQL Server 2000 Query Analyzer(查詢分析器)。MSDE為我們提供了一個命令行實用程序:osql。
>osql –S [servername] –U [login] –P [pwd] InstallSqlState.sql
為了獲取最大的可靠性,我們甚至可以對SQL Server進(jìn)行分組。這種模式是保護(hù)會話狀態(tài)的最有力的方法,不過從性能上而言,這種模式也是最為昂貴的。每個請求都需要在數(shù)據(jù)庫之間進(jìn)行往返,這會嚴(yán)重影響應(yīng)用程序進(jìn)行響應(yīng)。同時,利用網(wǎng)絡(luò)進(jìn)行處理也會由于高負(fù)荷而產(chǎn)生瓶頸問題。
您可能感興趣的文章:
  • Asp.net中判斷一個session是否合法的方法
  • 幾種判斷asp.net中session過期方法的比較
  • ASP.NET Session對象保持會話使用說明
  • asp.net session的使用與過期實例代碼

標(biāo)簽:棗莊 萍鄉(xiāng) 大理 衡水 衢州 蚌埠 廣元 江蘇

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net配置會話狀態(tài)Session實現(xiàn)代碼》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    上蔡县| 中牟县| 广南县| 成安县| 察哈| 黄浦区| 辽阳市| 禄丰县| 瑞安市| 阿克苏市| 资中县| 托克托县| 嘉义市| 禹城市| 勃利县| 德钦县| 乌鲁木齐市| 新蔡县| 洞口县| 台南县| 阿拉善右旗| 柘城县| 五指山市| 汉中市| 庄浪县| 龙井市| 肇庆市| 和顺县| 疏附县| 西畴县| 华池县| 香格里拉县| 佛学| 醴陵市| 朝阳县| 永靖县| 焦作市| 乐都县| 枣强县| 上杭县| 浠水县|