因为ASP.NET中Session的存取机制与ASP相同,都是保存在进行中,
一旦进程崩溃,所有Session信息将会丢失,所以我采取了将Session信息保存到SQL Server中,尽管还有其它的
几个方式(本文不作介绍),要将Session保存到SQL Server中,需要有以下几个步骤:
几个方式(本文不作介绍),要将Session保存到SQL Server中,需要有以下几个步骤:
一、
1.首先要创建用于保存Session数据的数据库,以命令行的形式用aspnet_regsql.exe来完成,具体命令为
C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727>aspnet_regsql.exe -ssadd -sstype c
-d sd -E
该命令是以windows验证方式,添加了sd数据库保存session数据。
2.需要修改ASP.NET web.config文件中的SessionState结点,该结点位于<system.web>下
<sessionState mode="SQLServer" allowCustomSqlDatabase="true"
sqlConnectionString="server=.;uid=sa;password=;initial catalog=sd"
cookieless="false"
timeout="20">
</sessionState>
这样一来,Session数据就不再是依赖于IIS进程而是保存到数据库中。可以打开sd数据库会有两个表分别为ASPStateTempSessions、ASPStateTempApplications。
C:\WINDOWS\Microsoft.NET\Framework\v2.0.50727>aspnet_regsql.exe -ssadd -sstype c
-d sd -E
该命令是以windows验证方式,添加了sd数据库保存session数据。
2.需要修改ASP.NET web.config文件中的SessionState结点,该结点位于<system.web>下
<sessionState mode="SQLServer" allowCustomSqlDatabase="true"
sqlConnectionString="server=.;uid=sa;password=;initial catalog=sd"
cookieless="false"
timeout="20">
</sessionState>
这样一来,Session数据就不再是依赖于IIS进程而是保存到数据库中。可以打开sd数据库会有两个表分别为ASPStateTempSessions、ASPStateTempApplications。
二、
1、
C:\Windows\Microsoft.NET\Framework\v2.0.50727\InstallSqlState.sql
在此路径找到SQL 创建ASPState 数据库 。(如果数据库已存在,则跳过此步)
2、
在程序的WEBCONFIG.CONFIG 文件中将
<sessionState mode="InProc" cookieless="false" timeout="60" />
改成
<sessionState mode="SQLServer" sqlConnectionString="server=10.200.253.21;pwd=cash*team2007;uid=EDP-C" cookieless="false" timeout="20"/>