首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >自定义属性的OnAuthorization中的FormsAuthentication.SetAuthCookie

自定义属性的OnAuthorization中的FormsAuthentication.SetAuthCookie
EN

Stack Overflow用户
提问于 2009-11-21 14:07:44
回答 2查看 2.1K关注 0票数 2

我正在尝试在asp.net mvc(C#)应用程序的自定义属性的OnAuthorization中设置身份验证cookie。

当会话到期(新会话)时,我将再次设置一个auth cookie,使其在用户注销之前可用。

我已经使用以下代码设置了身份验证cookie,

代码语言:javascript
复制
//set forms auth cookie
FormsAuthentication.SetAuthCookie(strUserName, true);

但是当我检查HttpContext.User.Identity.IsAuthenticated时,它返回false。

如何在自定义属性的OnAuthorization中设置身份验证cookie?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-11-21 14:18:52

设置身份验证cookie后,您不会自动填写Context.User,您需要执行以下操作:

代码语言:javascript
复制
Context.User = new GenericPrincipal (new GenericIdentity (strUserName, "Forms"), null);

其中,要使IsAuthenticated返回true,strUserName必须为非null且不为空。在下一个请求中,FormsAuthenticationModule应该设置Context.User,这样您就不需要做任何事情了。

票数 2
EN

Stack Overflow用户

发布于 2009-11-21 14:22:06

我怀疑您可能需要在设置auth cookie后重定向到新页面,然后在新页面上检查IsAuthenticated。我不完全记得这件事发生的顺序,但这让我想起了我遇到的一个问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1774674

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档