3

我创建了一个自定义主体类

public class FacebookPrincipal : ClaimsPrincipal
{
    public JObject Data { get; set; }
}

我想使用它。当用户登录时,我尝试设置

var fbP = new FacebookPrincipal { Data = user.Data };

Thread.CurrentPrincipal = fbP;
AuthenticationManager.User = fbP;
HttpContext.User = fbP;

它在我设置后立即工作,但是当我去 hohome/index价值丢失

var user = HttpContext.GetOwinContext().Authentication.User;
var bbbb = this.User;
var cccc = ClaimsPrincipal.Current;

上述所有方法都返回一个 Principal 类型ClaimsPrincipal并且强制转换为FacebookPrincipal返回 null。

如何设置自定义主体?

4

3 回答 3

3

ASP.NET 标识在分配给用户和线程ClaimsIdentityFactory之前使用默认值创建。ClaimsIdentity您应该创建自己的ClaimsIdentityFactory,您可以在其中添加或管理其他信息。

UserManager<IdentityUser> userManager 
          = new UserManager<IdentityUser>(new UserStore<IdentityUser>());
userManager.ClaimsIdentityFactory 
          = new MyClaimsIdentityFactory<IdentityUser>();

以下代码用于为 ClaimsIdentity 或其子类创建您的实现。

public class MyClaimsIdentityFactory<IUser> : ClaimsIdentityFactory<IUser> where IUser : IdentityUser
{
    public MyClaimsIdentityFactory(): base()
    {

    }
    public override System.Threading.Tasks.Task<System.Security.Claims.ClaimsIdentity> CreateAsync(UserManager<IUser> manager, IUser user, string authenticationType)
    {
        // Override Creation of ClaimsIdentity and return it.
    }
}
  • 确保您绝对需要继承 ClaimsIdentity。您可以将附加信息添加为声明。
  • 您应使用base.CreateAsync并将其合并Claims到您创建的ClaimsIdentity.
于 2013-11-04T10:58:24.927 回答
1

•确保您绝对需要继承ClaimsIdentity。您可以将附加信息添加为声明。

您应该小心为补充信息添加额外的声明,因为副作用可能会改变授权策略做出决策的方式。

于 2015-03-19T17:11:20.157 回答
0

正如@marisks 所建议的,您可以使用IUserClaimsStore存储第三方为您的用户发出的声明。仅当自定义声明访问是问题时。

此外,要在两个请求之间保持身份,请使用以下代码。

// One can create one's own Identity here.
var identity = await 
    UserManager.CreateIdentityAsync(user, 
                                    DefaultAuthenticationTypes.ApplicationCookie);

// Or add custom claims. Claims Stored in IUserClaimStore 
// are already populated by above creation.
identity.AddClaim(new Claim("ProfileDATA", "VALUE"));

AuthenticationManager.SignIn(new AuthenticationProperties() 
                                   { IsPersistent = isPersistent }, identity);
于 2014-03-20T11:16:09.620 回答