Я использую аутентификацию OWIN для своего проекта MVC5.
Это мой SignInAsync
private async Task SignInAsync(ApplicationUser user, bool isPersistent)
{
var AccountNo = "101";
AuthenticationManager.SignOut(DefaultAuthenticationTypes.ExternalCookie);
var identity = await UserManager.CreateIdentityAsync(user, DefaultAuthenticationTypes.ApplicationCookie);
identity.AddClaim(new Claim(ClaimTypes.UserData, AccountNo));
AuthenticationManager.SignIn(new AuthenticationProperties() { IsPersistent = isPersistent, RedirectUri="Account/Index"}, identity);
}
Как вы можете видеть, я добавил AccountNo
в список претензий.
Теперь, как я могу обновить эту претензию в какой-то момент своего приложения? Пока у меня есть это:
public string AccountNo
{
get
{
var CP = ClaimsPrincipal.Current.Identities.First();
var Account= CP.Claims.FirstOrDefault(p => p.Type == ClaimTypes.UserData);
return Account.Value;
}
set
{
var CP = ClaimsPrincipal.Current.Identities.First();
var AccountNo= CP.Claims.FirstOrDefault(p => p.Type == ClaimTypes.UserData).Value;
CP.RemoveClaim(new Claim(ClaimTypes.UserData,AccountNo));
CP.AddClaim(new Claim(ClaimTypes.UserData, value));
}
}
когда я пытаюсь удалить заявку, я получаю это исключение:
Претензия 'http://schemas.microsoft.com/ws/2008/06/identity/claims/userdata: 101 'не удалось удалить. Это либо не является частью этого Идентичность или это требование, которое принадлежит Принципалу, которое содержит эта Идентичность. Например, Принципал будет владеть выражением, когда создавая GenericPrincipal с ролями. Роли будут выставлены через Identity, который передается в конструкторе, но не фактически принадлежащих Identity. Подобная логика существует для RolePrincipal.
Может ли кто-нибудь помочь мне выяснить, как обновить заявку?