我试图为一个MVC5网站(在VS2012)设置OAuth。
我使用Fluent NHibernate。我设置了我自己的Userstore和传递一个仓库对象访问NHibernate会话对象。我把我的商店送到默认的aspnet usermanager提供程序。这最终为本地注册和登录工作。我不尝试设置连接/注册到Facebook。
它获得了一个成功的帐户。在用户表中添加一个用户,在登录表中添加一条记录,然后冒出来。我没有在用户存储中实现声明,或在用户对象中放置声明集合。 (不知道这是否实际需要,我剥离一切可能会错误找到问题的根源)。
爆炸的线是,(在帐户控制器中):
var identity = await UserManager.CreateIdentityAsync(user,DefaultAuthenticationTypes.ApplicationCookie);
在此方法内:
private async Task SignInAsync(IdentityUser user,bool isPersistent)
这是堆栈跟踪的结束
[ArgumentNullException: Value cannot be null. Parameter name: value] System.Security.Claims.Claim..ctor(String type,String value,String valueType,String issuer,String originalIssuer,ClaimsIdentity subject,String propertyKey,String propertyValue) +14108789 System.Security.Claims.Claim..ctor(String type,String valueType) +62 Microsoft.AspNet.Identity.<CreateAsync>d__0.MoveNext() +481 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) +144 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) +84 System.Runtime.CompilerServices.TaskAwaiter`1.GetResult() +49 Web.Controllers.<SignInAsync>d__42.MoveNext() in d:\Google Drive\Development\GoalManagement\Web\Controllers\AccountController.cs:375 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) +144 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) +84 Web.Controllers.<ExternalLoginConfirmation>d__35.MoveNext() in d:\Google Drive\Development\GoalManagement\Web\Controllers\AccountController.cs:311 System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task) +144 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) +84 public class IdentityUser : IUser { public IdentityUser() { Logins = new List<IdentityUserLogin>(); } public string Id { get; set; } public string UserName { get; set; } public string PasswordHash { get; set; } public string SecurityStamp { get; set; } public IList<IdentityUserLogin> Logins { get; set; } } public class IdentityUserLogin { public string LoginProvider { get; set; } public string ProviderKey { get; set; } }
如果需要,我可以包括我的用户存储代码:我没有把它,因为它是一个大文件,可能减少问题。
我不知道为什么它甚至试图创建声明对象,为什么它爆炸。由于我只有VS2012我已经修补它所有在一起从例子在线主要。
正如@Shoe我建议从UserManager继承:
public class NHibernateAspnetUserManager<TUser> : UserManager<TUser> where TUser : IdentityUser { public NHibernateAspnetUserManager(IUserStore<TUser> store) : base(store) { } public override Task<ClaimsIdentity> CreateIdentityAsync(TUser user,string authenticationType) { ClaimsIdentity identity = new ClaimsIdentity(); return Task.FromResult(identity); } }
它现在不再引发错误,但实际上不认证我多少次使用Facebook注册/登录。
总结。使用@ Shoe的信息我试过覆盖UserManager.CreateIdentityAsync与:
public override Task<ClaimsIdentity> CreateIdentityAsync(TUser user,string authenticationType) { var identity = new ClaimsIdentity(); identity.AddClaim(new Claim(ClaimTypes.Name,user.UserName)); return Task.FromResult(identity); }
并尝试实现IUserClaimStore与返回的默认(空列表)。
第一个不会通过错误,但不会结束验证。后来仍然会通过奇怪的索赔“System.Security.Claims.Claim..ctor”错误
编辑
找到为什么ctor错误发生。用户对象回来没有ID,所以默认的UserManager得到失败。固定和使用默认UserManager现在不再引发错误,但仍然不记录用户。其返回的身份对象看起来从我可以告诉。