微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – .Net Forms身份验证是否需要会话?

我们正在讨论表单身份验证的确如何运作.

是否所有标识用户的信息都存储在cookie中,或者是否存储在会话中的某些信息?

解决方法

有关正在进行身份验证的用户的信息存储在 FormsAuthenticationTicket中的cookie中,名称为.ASPXAUTH.

有关用户会话的信息与有关身份验证的信息不同.会话的标识符可以存储在cookie(与认证cookie不同的cookie)中,或者如Henk所指出的,在无cookie会话中,即作为URL的一部分.

用户会话中存储有关身份验证的一些信息的问题是,在PostAcquireRequestState处理管道中的身份验证事件(后续5个事件IIRC)之后的一段时间内,会话才可用.这意味着您将无法访问身份验证会话中的数据,直到认证后!

可以在会话中存储数据并用该数据覆盖IIdentity和IPrincipal,但这确实意味着用户身份将在会话可用之前具有事件的一些数据,并且会话之后的事件的不同数据可用,这可能是或者可能不是问题.此外,您可能希望以某种方式以加密方式保护会话中的数据.

要回答标题问题,表单身份验证不需要会话;它们是不同目的所需的不同实体.

原文地址:https://www.jb51.cc/csharp/98091.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐