关于触发asp.net Global.asax Session_End事件的经验

   在做asp.net编程开发的时候,我遇见这样的问题,一个用户只能在一台机器上登录,

如果有用户在其他机器上登录,系统将提示该用户已经登录!当前登陆非法!我的做法是:

用Application变量保存已经Login的用户信息,当Session_Start的时候,在Global.asax

文件里写Session_Start事件响应函数,记录登录用户!当用户Logout的时候,在Session_End

事件里,将Application变量中的用户信息做一个休正,即:清除SessionEnd的用户信息。

问题出现了!Session_End无法执行???为什么呢?后来看了几篇文章,做了试验,得出以下

结果,要让Session_End事件响应,需要做以下工作:        

首先在web.config文件中需要有以下设置:

<sessionState
            mode="InProc"
            stateConnectionString="tcpip=127.0.0.1:42424"
            sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes"
            cookieless="false"
            timeout="1"
    /> 

Session_End只在mode="inProc"模式下触发,timeout决定该事件的触发时间,

一般情况下,timeout是指Session失效的时间,我在自己设计的asp.net应用系统中,

使用Form校验方式,不需要Session来判断用户是否登录,所以设置timeout=1分钟,

不会影响正常操作,但是如果用户设计的系统使用Session来保存用户登录信息,

设置timeout=1,那么打开浏览器后,当用户在1分钟内不在该浏览器上进行操作,

Session就会失效,这可能导致系统使用的不正常!对于一般用户而言,对着屏幕

看1分钟后,又要重新登陆一次,是个十分恶心的事情!

 

           因此,如果使用Session来保存用户登录信息,建议采用其他方式!

比如在每个Page上做一个onunload事件响应函数,如:oncloseIE(),当浏览器关闭的时候,

oncloseIE()执行,在oncloseIE函数里使用ajax方式,调用后台的server端函数,执行

Session.Abandon(); 这样的方法将是最直接,最及时的Session End处理!


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值