我应该在LogOff方法中使用Session.Abandon()吗?

时间:2011-02-15 17:54:58

标签: asp.net-mvc forms-authentication session-state

我正在使用的技术:

  • MVC v2
  • 表单身份验证(滑动到期)
  • 会话状态服务器
  • 自定义授权属性

我正在为我的mvc app使用状态服务器进程。在测试期间,当经过身份验证的用户单击“LogOff”按钮时,它将正确地将他们带到身份验证屏幕,并且在成功输入凭据后,会将其重新登录。但是,它会找到他们之前的会话变量状态,而不是重新加载我给他们的任何新权限。这是由于我在以下代码中加载用户的方式:

public override void OnAuthorization(AuthorizationContext filterContext) {

        if (filterContext == null)
            throw new ArgumentNullException("FilterContext");

        if (AuthorizeCore(filterContext.HttpContext)) {
            IUser customUser = filterContext.HttpContext.Session["CustomUser"] as IUser;

            if ((customUser == null) || (customUser.Name != filterContext.HttpContext.User.Identity.Name)) {
                customUser = new User(filterContext.HttpContext.User.Identity.Name,
                                      filterContext.HttpContext.User.Identity.IsAuthenticated);
            }

            if (_privileges.Length > 0) {
                if (!customUser.HasAtLeastOnePrivilege(_privileges))
                    filterContext.Result = new ViewResult { ViewName = "AccessDenied" };
            }

            filterContext.HttpContext.Session["CustomUser"] = customUser;
        }
    }

所以,你可以看到我将customUser存储在Session中,并且该值是从前一个会话中获取的值,即使用户已经注销(但已重新登录)滑动到期窗口。

所以,我的问题是,我应该在Session.Abandon()中的LogOff方法中进行简单的AccountController调用,还是有更清洁,更有利的方法来处理这个问题?

1 个答案:

答案 0 :(得分:7)

通常Session.Clear()应该足够并删除会话中存储的所有值。 Session.Abandon()结束当前会话。它也可能触发Session_End,下一个请求将触发Session_Start。