当前位置: 代码迷 >> 应用服务器 >> Session丢失有关问题解决方案
  详细解决方案

Session丢失有关问题解决方案

热度:10279   发布时间:2013-02-26 00:00:00.0
Session丢失问题解决方案
作者未知

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 "。  
  相关解决方案