FormsAuthentication.SignOut抛出NullReferenceException

时间:2011-07-06 23:22:40

标签: c# formsauthentication

此问题似乎与this帖有关,但我无法从该帖子推断出解决方案。

我在我继承的应用程序中注意到这个代码(在日志文件中注意到正在吃异常):

    protected void Session_End(object sender, EventArgs e)
    {
        try
        {
            FormsAuthentication.SignOut();
            FormsAuthentication.RedirectToLoginPage();
            //if (this.Context.Handler is IRequiresSessionState || this.Context.Handler is IReadOnlySessionState)
            //{
            //    FormsAuthentication.SignOut();
            //    FormsAuthentication.RedirectToLoginPage();
            //}
        }
        catch (Exception ex)
        {
            this.GetType().GetLogger().Error(ex);
        }
    }

我想知道一些事情。首先,SignOut如何抛出空引用异常?这是一个例外情况,还是我在我的计划中做了一些天生错误的事情?接下来,在抛出此异常之前,我应该测试什么来阻止它?

  

15:51:57,288 [13]错误ASP.global_asax - System.NullReferenceException:对象引用未设置为对象的实例。      在System.Web.Security.FormsAuthentication.SignOut()      在MvcApplication.Session_End

由于

1 个答案:

答案 0 :(得分:14)

重要的是要意识到Session_End不一定在HTTP请求的上下文中执行。它可能会在会话超时时运行。你当时不能向客户发送任何东西,因为它根本就不存在了!

因此,您不应尝试删除Session_End中的表单身份验证Cookie。如果您愿意,在应用程序中的某处单击“注销”按钮时,应该尽快完成。如果您需要用户的表单身份验证票证在超时发生后到期,您只需在配置文件中适当地设置cookie到期时间(可能相当于会话超时值)。