session丟失已經是一種習以為常的問題了,在自己也了解一些如何解決的問題,但是也一直沒有機會去用,現在由于新的項目要在b/s下開發,所以不得不讓我考慮session的問題。
解決session丟失的問題有兩種方法:1)將session保存在一臺sate server中。2)將session保存在sql server中。我們使用的數據庫是oracle,不想再裝一個數據庫,所以用了第一種方法。
首先根據網上查的資料對webconfig文件中session部分進行修改。如下:
<sessionstate
mode="stateserver"
cookieless="false"
timeout="240"
stateconnectionstring="tcpip=10.164.222.122:42424"
statenetworktimeout="14400"
/>
<machinekey
validationkey="78ae3850338bfadce59d8ddf58c9e4518e7510149c46142d7aad7f1ad49d95d4"
decryptionkey="5fc88dfc24ea123c"
validation="sha1"
/>
然后再在10.164.222.122 這臺電腦上的asp.net state server 服務啟動
這樣基本上就行了。體驗一下。
我用了一個測試程序,在3個小時以后session仍然可用,更絕的是我的電腦都重起了,在其它電腦上打開的網頁中session仍然可用。一番體驗以后,感覺還真不錯。
.net framework 常規參考
<sessionstate> 元素
為當前應用程序配置會話狀態設置。
<configuration>
<system.web>
<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 指定在哪里存儲會話狀態。
off 指示會話狀態未啟用。
inproc 指示在本地存儲會話狀態。
stateserver 指示在遠程計算機上存儲會話狀態。
sqlserver 指示在 sql server 上存儲會話狀態。
可選屬性
屬性 選項 說明
cookieless 指定不具有 cookie 的會話是否應用于標識客戶端會話。
true 指示應使用不具有 cookie 的會話。
false 指示不應使用沒有 cookie 的會話。默認值為 false。
timeout 指定在放棄一個會話前該會話可以處于空閑狀態的分鐘數。默認值為 20。
stateconnectionstring 指定遠程存儲會話狀態的服務器名稱和端口。例如“tcpip=127.0.0.1:42424”。當 mode 為 stateserver 時該屬性是必需的。
sqlconnectionstring 為 sql server 指定連接字符串。例如“data source=localhost;integrated security=sspi;initial catalog=northwind”。當 mode 為 sqlserver 時該屬性是必需的。
statenetworktimeout 在使用 stateserver 模式存儲會話狀態時,指定在放棄會話之前 web 服務器和狀態服務器之間的 tcp/ip 網絡連接空閑的時間(以秒為單位)。默認值為 10。
備注
使用 stateserver 模式
確保運行 asp.net 狀態服務的服務器是要存儲會話狀態信息的遠程服務器。該服務與 asp.net 一起安裝,其默認位置為 <驅動器>:/systemroot/microsoft.net/framework/version/aspnet_state.exe。
在應用程序的 web.config 文件中,設置 mode=stateserver 并設置 stateconnectionstring 屬性。例如,stateconnectionstring="tcpip=sarath:42424"。
使用 sqlserver 模式
在運行 sql server 的計算機(它將存儲會話狀態)上運行 installsqlstate.sql(默認的安裝位置為 <驅動器>:/systemroot/microsoft.net/framework/version)。這將創建一個名為 aspstate 的數據庫,該數據庫具有新的存儲過程并且在 tempdb 數據庫中具有 aspstatetempapplications 表和 aspstatetempsessions 表。
在應用程序的 web.config 文件中,設置 mode=sqlserver 并設置 sqlconnectionstring 屬性。例如,sqlconnectionstring="data source=localhost;integrated security=sspi;initial catalog=northwind"。
示例
以下示例指定若干會話狀態配置設置。
<configuration>
<system.web>
<sessionstate mode="inproc"
cookieless="true"
timeout="20"/>
</sessionstate>
</system.web>
</configuration>
要求
包含于:<system.web>
web 平臺:iis 5.0、iis 5.1、iis 6.0
配置文件:machine.config、web.config
配置節處理程序:system.web.sessionstate.sessionstatesectionhandler
請參見
asp.net 配置 | asp.net 設置架構 | sessionstatemodule
新聞熱點
疑難解答