asp.net删除文件夹后引起Session丢失的解决办法

最简单的办法就是不要使用默认的方式也即 
InProc(默认,进程内的会话状态):Session存储在IIS进程中(Web服务器内存)。如果使用的是Windows 2000 Server或Windows XP,IIS使用aspnet_wp.exe进程,如果使用的是Windows 2003 Server,IIS使用w3wp.exe。 

InProc拥有最好的性能。但进程内Session很容易丢失Session信息。如果重启了应用程序,所有的Session信息就会丢失。而很多原因都会导致ASP.NET应用程序的重启。 
 修改了Web.Config或Global.asax文件,或改变了文件的修改日期。 
 修改了\bin或\App_Code目录里的文件。 
 防病毒软件修改了上述文件等等 

你可以考虑以下两种方式 
1、StateServer(进程外的会话状态):Session存储在独立的Windows服务进程aspnet_state.exe中 

如果要启用StateServer中的Session状态,首先要在”控制面板”--“管理工具”--“服务”中,启用ASP.NET State Services(ASP.NET 状态服务),并将此服务设置为Automatic(自动启动) 

启动ASP.NET状态服务后,需要配置ASP.NET应用程序来使用它。 
我们需要在Web.Config文件中system.web节点中添加如下代码 
<sessionState mode="StateServer" stateNetworkTimeout="20" 
stateConnectionString="tcpip=127.0.0.1:42424" /> 
首先,mode属性被设为StateServer。接着,stateConnectionString属性用来指定ASP.NET状态服务器端的位置。连接位置被创建为在127.0.0.1,端口42424。最后,stateNetworkTimeout属性用来指定连接超时的秒数。 
需要注意的是,此时必须把对象标注为可序列化后(使用Serializable特性标记需要序列化的类)才能在服务中进行存储。Microsoft建议所有的开发人员在开发过程中都使用进程外的会话状态,以避免项目如果切换到其他进程外的提供程序或SqlServer而导致站点的错误。 

或者使用 
2、SqlServer:Session存储在SqlServer数据库的表中,可以用aspnet_regsql.exe配置它(SqlServer服务器)

还一种办法是釆用虚拟目录的方法:

前提是你有再web(项目文件夹)站点下建立虚拟目录的权限,并且可以将虚拟目录指定到web文件夹外部

比如应用程序的上传文件夹是/Uploadfiles,那么需要在IIS中给web站点下面建立一个Uploadfiles虚拟目录,并指向web文件夹外部的另一个文件夹。

并且删除web下面的uploadfiles物理目录

这样子就可以绕过修改web文件结构而引起session丢失的问题,实现删除文件夹而不会引起应用程序重启

转载于:https://www.cnblogs.com/fmxyw/archive/2010/01/15/1648469.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值