使用实体框架6.0.0-rc1的asp.net标识版本1.0.0-rc1 (与Visual Studio2013 RC一起提供的版本)。
试图让用户有机会更改他们的UserName
。在AuthenticationIdentityManager
下似乎没有这样的功能,所以我使用EF (获取当前用户的用户对象,更改UserName并保存更改)来更改数据。
问题是身份验证cookie保持不变,下一个请求失败,因为没有这样的用户。
在过去的表单身份验证中,我使用以下代码来解决这个问题。
var formsAuthCookie = Request.Cookies[FormsAuthentication.FormsCookieName];
var isPersistent = FormsAuthentication.Decrypt(formsAuthCookie.Value).IsPersistent;
FormsAuthentication.SetAuthCookie(newUserName, isPersistent);
我应该如何处理asp.net标识以更新cookies?
更新
下面的代码似乎更新了身份验证cookie。
var identity = new ClaimsIdentity(User.Identity);
identity.RemoveClaim(identity.FindFirst(identity.NameClaimType));
identity.AddClaim(new Claim(identity.NameClaimType, newUserName));
AuthenticationManager.AuthenticationResponseGrant = new AuthenticationResponseGrant
(new ClaimsPrincipal(identity), new AuthenticationProperties {IsPersistent = false});
剩下的问题是:如何从当前身份验证IsPersistent
中提取cookie值?
发布于 2013-10-14 14:56:56
How do you login/authenticate a user with Asp.Net MVC5 RTM bits using AspNet.Identity?
private async Task SignInAsync(ApplicationUser user, bool isPersistent)
{
AuthenticationManager.SignOut(DefaultAuthenticationTypes.ExternalCookie);
var identity = await UserManager.CreateIdentityAsync(user, DefaultAuthenticationTypes.ApplicationCookie);
AuthenticationManager.SignIn(new AuthenticationProperties() { IsPersistent = isPersistent }, identity);
}
对于RC1,您可以使用类似的代码。
AuthenticationManager.SignOut();
IdentityManager.Authentication.SignIn(AuthenticationManager, user.UserId, isPersistent:false);
对于持久值,您需要访问身份验证cookie并检索状态。
更新:
使用适当的AuthenticationType来代替“持有者”。还要确保在发布登录票证的同时,设置AuthenticationProperties.IsPersistent。
bool isPersistent=false;
var authContext = await Authentication.AuthenticateAsync("Bearer");
if (authContext != null)
{
var aProperties = authContext.Properties;
isPersistent = aProperties.IsPersistent;
}
https://stackoverflow.com/questions/19349011
复制相似问题