关于session的用法

在平常,session经常莫名奇妙的丢失,发现服务器将Session信息存储在IIS进程中。当IIS关闭、重起后,这些信息都会丢失。但是这种模式也有自己最大好处,就是性能最高

<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 
设置将Session信息存储到哪里 
Off 
设置为不使用Session功能 
InProc 
设置为将Session存储在进程内,就是ASP中的存储方式,这是默认值。 
StateServer 
设置为将Session存储在独立的状态服务中。 
SQLServer 
设置将Session存储在SQL Server中。 

可选的属性是: 
属性 选项 描述
cookieless 
设置客户端的Session信息存储到哪里 
ture 
使用Cookieless模式 
false 
使用Cookie模式,这是默认值。 

timeout 
设置经过多少分钟后服务器自动放弃Session信息。默认为20分钟 
stateConnectionString 
设置将Session信息存储在状态服务中时使用的服务器名称和端口号,例如:"tcpip=127.0.0.1:42424”。当mode的值是StateServer是,这个属性是必需的。 

sqlConnectionString 
设置与SQL Server连接时的连接字符串。例如"data source=localhost;Integrated Security=SSPI;Initial Catalog=northwind"。当mode的值是SQLServer时,这个属性是必需的。 

stateNetworkTimeout 
设置当使用StateServer模式存储Session状态时,经过多少秒空闲后,断开Web服务器与存储状态信息的服务器的TCP/IP连接的。默认值是10秒钟。

 

 

 

Session状态应该存储在两个地方,分别是客户端和服务器端。客户端只负责保存相应网站的SessionID,而其他的Session信息则保存在服务器端。在ASP中,客户端的SessionID实际是以Cookie的形式存储的。如果用户在浏览器的设置中选择了禁用Cookie,那末他也就无法享受Session的便利之处了,甚至造成不能访问某些网站。为了解决以上问题,在ASP.NET中客户端的Session信息存储方式分为:CookieCookieless两种

 

把这段话中的cookieless="false"改为:cookieless="true",这样,客户端的Session信息就不再使用Cookie存储了,而是将其通过URL存储。关闭当前的IE,打开一个新IE,重新访问刚才的Web应用程序,就会看到类似下面的样子: IT其中,http://localhost/MyTestApplication/(ulqsek45heu3ic2a5zgdl245)/default.aspx中黑体标出的就是客户端的Session ID。注意,这段信息是由IIS自动加上的,不会影响以前正常的连接。

 

 

在使用StateServer或者SQLServer存储Session时,所有需要保存到Session的对象除了基本数据类型(默认的数据类型,如intstring等)外,都必须序列化。只需将[Serializable]标签放到要序列化的类前就可以了。
如:
[Serializable]
public class MyClass
{}

 

引用

http://blog.csdn.net/huaer1011/archive/2008/04/18/2304936.aspx

 

posted on 2008-07-30 09:37  小白鸭  阅读(226)  评论(0)    收藏  举报

导航