ASP.NET中Session的个人浅谈
看到博客园的一个哥们写的面试经历,想到了面试中常问到的Session,一时手痒就谈下自己对Session的理解,这东西最开始在用户登录登出的时候用到过,后来一直没怎么用过,里面还是有很多知识点值得注意的。先简单的说下吧,Session是分为客户端Session和服务端Session:
客户端Session
Session称为会话状态,是Web系统中最常用的状态,用于维护和当前浏览器实例相关的一些信息,当用户首次与Web服务器建立连接的时候,服务器会给当前访问用户分发一个 SessionID作为标识。SessionID是一个由24个字符组成的随机字符串。用户每次提交页面,浏览器都会把这个SessionID包含在 Http头中提交给Web服务器,这样Web服务器就能区分当前请求页面的是哪一个客户端。这个SessionID就是保存在客户端的,属于客户端Session.(ASP.NET中你如果访问一个后台处理页面,可以用Session.SessionID取值)。
客户端Session默认是以cookie的形式来存储的,所以当用户禁用了cookie的话,服务器端就得不到SessionID。这个时候你可以通过重写URL,你可以在全局处理程序Global.asax中Application_Start方法中正则匹配一下将SessionID直接写在新的url中。
服务端的Session也就是我们最常用的,为了更好的使用服务端的Session,可以先看一下SessionStateMode这个枚举:
public enum SessionStateMode
{
// 摘要:
// 会话状态被禁用。
Off = ,
//
// 摘要:
// 会话状态正在处理 ASP.NET 辅助进程。
InProc = ,
//
// 摘要:
// 会话状态正在使用进程外 ASP.NET 状态服务存储状态信息。
StateServer = ,
//
// 摘要:
// 会话状态正在使用进程外 SQL Server 数据库存储状态信息。
SQLServer = ,
//
// 摘要:
// 会话状态正在使用自定义数据存储来存储会话状态信息。
Custom = ,
}
Inproc(进程内)模式
此模式将会话状态存储在 Web 服务器上的内存中,这是默认设置,是唯一支持Session_OnEnd 事件的模式。Session数据保存在IIS的inetinfo.exe进程中,这个方式是最常用的,性能最高,比较简单,唯一的缺点就是IIS重启的时候Session会丢失。
StateServer(状态服务器)模式
StateServer 模式将会话状态存储在一个称为 ASP.NET 状态服务的进程中(服务中的ASP.NET State Service服务 ),该进程是独立于 ASP.NET 辅助进程或 IIS 应用程序池的单独进程。这种情况下Session会被保存在Asp.Net进程之外的aspnet_state.exe进程中,这个进程不受asp.net进程回收的影响。
若要将某个 ASP.NET 应用程序配置为使用 StateServer模式,可以在Web.config文件中配置:将 SessionState元素的 mode属性设置为StateServer,将
stateConnectionString属性设置为tcpip=服务器名称:42424。Web.Config中的配置如下:
<sessionState mode="StateServer" stateConnectionString="tcpip=服务器地址:42424" cookieless="false" timeout=""/>
(如果是本地设成127.0.0.1就行,端口是默认的,如果想修改的话可以去注册表中修改)
SQL Server 模式
SqlServer模式将会话状态存储到一个 SQL Server 数据库中,可以确保在重新启动 Web 应用程序时保留会话状态,如果是 SQL Server模式,则存储在会话状态中的对象必须是可序列化的.
若要使用SqlServer模式,首先要在 SQL Server上安装了 ASP.NET 会话状态数据库。可以使用 Aspnet_regsql.exe 工具安装 ASP.NET 会话状态数据库。
使用 Aspnet_regsql.exe 工具安装会话状态数据库
C:\Windows\Microsoft.NET\Framework64\v4.0.30319(选择NET版本,里面都有Aspnet_regsql.exe)
状态数据库是需要在命令行中执行如下命令:aspnet_regsql.exe -S local -E -ssadd -sstype p
执行之后我们可以看到如下两张表:

-sstype之后的参数是可选的
t 将会话数据存储到 SQL Server tempdb 数据库中。这是默认设置。如果将会话数据存储到 tempdb 数据库中,则在重新启动 SQL Server 时将丢失会话数据。
p 将会话数据存储到 ASPState 数据库中,而不是存储到 tempdb 数据库中。
c 将会话数据存储到自定义数据库中。如果指定 c 选项,则还必须使用 -d 选项包括自定义数据库的名称
(详细命令可参考http://msdn.microsoft.com/zh-cn/library/ms229862(v=vs.100).aspx)
自定义模式
Custom模式指的是定义会话状态存储提供程序来存储会话状态数据。一般情况下你如果用的SQL Server就没必要使用自定义存储,使用的Oracle或者MySQL可以使用(没有实际操作过),你可以通过创建一个继承SessionStateStoreProviderBase 类的类,来实现自定义会话状态存储提供程序。然后在配置文件中进行相关配置,详情请参考http://msdn.microsoft.com/zh-cn/library/ms178587(v=vs.80).aspx.
小结
Session的默认保存在在IIS其实性能最高的,只是有的时候不稳定会丢失,Session的生命周期都是第一次访问的时候创建,超时销毁,StateServer和SQLSERVER存储的话由于序列化和反序列化的原因会消耗CPU资源,SQLServer从数据库读取的速度也不快,默认的有的时候还是挺不错的,Session的建议不要存放大量数据。单个销毁Session的之后可以用Session.Remove("名称"),销毁所有:Session.Abandon()或者Session.Clear()。
如果是构建高性能可扩展的ASP.NET网站中使用Session,那么必须解决一个的问题就是分布式Session的架构,由于本人行业限制,没有涉及到这一块,园友有人提出了解决方案,具体可参考http://www.cnblogs.com/luminji/archive/2011/11/03/2195704.html。
ASP.NET中Session的个人浅谈的更多相关文章
- .net中对象序列化技术浅谈
.net中对象序列化技术浅谈 2009-03-11 阅读2756评论2 序列化是将对象状态转换为可保持或传输的格式的过程.与序列化相对的是反序列化,它将流转换为对象.这两个过程结合起来,可以轻松地存储 ...
- ASP.NET中Session的sessionState 4种mode模式
1. sessionState的4种mode模式 在ASP.NET中Session的sessionState的4中mode模式:Off.InProc.StateServer及SqlServer. 2. ...
- 判断asp.net中session过期的方法
判断asp.net中session过期的方法 转载自:http://www.cnblogs.com/xilipu31/archive/2013/04/12/3016830.html 方法一:最麻烦也是 ...
- 对kotlin和java中的synchronized的浅谈
synchronized在java中是一个关键字,但是在kotlin中是一个内联函数.假如分别在java和kotlin代码锁住同一个对象,会发生什么呢,今天写了代码试了试.首先定义people类 12 ...
- C++ STL中的常用容器浅谈
STL是C/C++开发中一个非常重要的模板,而其中定义的各种容器也是非常方便我们大家使用.下面,我们就浅谈某些常用的容器.这里我们不涉及容器的基本操作之类,只是要讨论一下各个容器其各自的特点.STL中 ...
- CSS属性中的display属性浅谈;
首先我们要知道什么是块级元素和行内元素有什么区别: 承接上篇文章:(浅谈HTML和body标签) 块级元素:浏览器解析为独占一行的元素(例如:div.table.ul等.),浏览器会在该元素的前后显示 ...
- asp.net中Session过期设置方法
在Asp.net应用中,很多人会遇到Session过期设置有冲突.其中,可以有四处设置Session的过期时间: 一.全局网站(即服务器)级 IIS-网站-属性-Asp.net-编辑配置-状态管理-会 ...
- ASP.Net中Session失效的一种编程思路
在写一个客户的B/S结构应用程序时,突然发现一个技巧,不知道是否是MS的一个BUG,给相关的有研究的朋友原先考虑写一个检查Session的类,Session失效后,必须转向登陆页面,可每一个调用该类的 ...
- asp.net中session的原理及应用
Session简介丶特性 1.Session是一种Web会话中的常用状态之一. 2.Session提供了一种把信息保存在服务器内存中的方式.他能储存任何数据类型,包含自定义对象. 3.每个客户端的Se ...
随机推荐
- bootstrap css-网格系统
前言:第一次记录点东西,只能勉强算是笔记吧.博主自学前端,深知自己水水的,但还是向把自己学到的东西记录下来,这不刚学习了bootstrap的css部分,现在整理出笔记. 1,Bootstrap网格系统 ...
- HDU5320 : Fan Li
考虑枚举左端点i,则随着右端点的右移,一共只有$O(\log n)$种不同的gcd取值.所以首先通过ST表+二分查找预处理出$O(n\log n)$个四元组(x,i,l,r),表示左端点为i,右端点取 ...
- hdu 5752 Sqrt Bo 水题
Sqrt Bo 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5752 Description Let's define the function f ...
- 解决oracle语句中 含数字的字符串按数字排序问题
普通排序利用:order by 字段名 ASC 但是遇到有中文而且类型是varchar类型的结果就是这样 政采代(甲)字第0298号 政采代(甲)字第0421号 政采代(甲)字第1098号 政采代(甲 ...
- Snmp学习总结(六)——linux下安装和配置SNMP
一.安装SNMP 1.1.下载Net-SNMP的源代码 选择一个SNMP版本,比如5.7.1,下载地址如下:http://sourceforge.net/projects/net-snmp/files ...
- Android Service总结04 之被绑定的服务 -- Bound Service
Android Service总结04 之被绑定的服务 -- Bound Service 版本 版本说明 发布时间 发布人 V1.0 添加了Service的介绍和示例 2013-03-17 Skywa ...
- 字符串类型的变量,也要进行alloc内存分配之后才能用
nss_upperName =[[NSStringalloc]initWithString:labTopTitle.text]; nss_upperName =labTopTitle.text; // ...
- mysql 和 sqlite 区别 及 SQLite Expert Professional sqliteManager 区别
mysql 和 sqlite 区别 SQLITE是单机数据库.功能简约,小型化,追求最大磁盘效率MYSQL是完善的服务器数据库.功能全面,综合化,追求最大并发效率 MYSQL.Sybase.Oracl ...
- 【C++】拷贝构造函数和赋值符函数
在C++中,调用拷贝构造函数有三种情况: 1.一个对象作为函数参数,以值传递的方式传入函数体. 2.一个对象作为函数返回值,以值传递的方式从函数返回. 3.一个对象用于给另外一个对象进行初始化(复制初 ...
- UICollectionViewFlowLayout使用示例
UICollectionViewFlowLayout使用示例 效果 源码 https://github.com/YouXianMing/iOS-Project-Examples // // ViewC ...