博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何应对Session丢失》》State Server
阅读量:6327 次
发布时间:2019-06-22

本文共 2613 字,大约阅读时间需要 8 分钟。

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.SessionStateSectionHandle

转载地址:http://psgaa.baihongyu.com/

你可能感兴趣的文章
学习过程中的好文章集合
查看>>
阿花宝宝 Java基础笔记 之 流程控制(二)
查看>>
Web 2.0应用客户端性能问题十大根源
查看>>
javascript 的基本优化
查看>>
字符计数
查看>>
memcached+net缓存
查看>>
Spring整合Quartz定时任务执行2次,Spring定时任务执行2次
查看>>
【设计模式】工厂方法模式
查看>>
【转载】Win10系统如何设置所有程序默认以管理员身份运行?
查看>>
面向对象第六章(接口、强转、多态)
查看>>
winform中的Json解析
查看>>
UVa 1151 Buy or Build(最小生成树+枚举子集)
查看>>
php中引用&的真正理解-变量引用、函数引用、对象引用
查看>>
tomcat 下War包部署方法
查看>>
软件工程自评
查看>>
存储过程
查看>>
转载--C# PLINQ 内存列表查询优化历程
查看>>
调用函数后加括号与不加括号的区别
查看>>
Linq左右連接
查看>>
Mysql 一些命令记录
查看>>