国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

使Session不丟失的方法之一的體驗

2024-07-21 02:29:50
字體:
來源:轉載
供稿:網友

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商河县| 民权县| 库车县| 澄迈县| 大足县| 民县| 清涧县| 达尔| 喀什市| 蓝田县| 河西区| 赣榆县| 即墨市| 基隆市| 九寨沟县| 肇东市| 五家渠市| 和平区| 肥西县| 涿州市| 乐昌市| 大同市| 鱼台县| 屏南县| 达孜县| 汾西县| 嘉定区| 桦甸市| 新巴尔虎左旗| 齐齐哈尔市| 洮南市| 铁力市| 海淀区| 西安市| 焦作市| 祥云县| 石柱| 普洱| 吉木萨尔县| 溧阳市| 专栏|