关于与Ninject
的绑定,我遇到了一些编译器错误。这是代码:
kernel.Bind<IUserStore<ApplicationUserStore>>().To<UserStore<ApplicationUser, ApplicationRole, int, ApplicationUserLogin, ApplicationUserRole, ApplicationUserClaim>>().InRequestScope();
kernel.Bind<IRoleStore<ApplicationRoleStore>>().To<RoleStore<ApplicationRole, int, ApplicationUserRole>>().InRequestScope();
这些是编译器错误:
错误5类型"MyNamespace.Data.ApplietonRoleStore"不能用作泛型类型或方法"Microsoft.AspNet.Identity.IRoleStore"中的类型参数"TRole"。没有从"MyNamespace.Data.AppliatonRoleStore"到"Microsoft.AspNet.Identity[IRole"的隐式引用转换。
错误6类型"MyNamespace.Data.ApplietonRoleStore"不能用作泛型类型或方法"Microsoft.AspNet.Identity.IRoleStore"中的类型参数"TRole"。没有从"MyNamespace.Data.AppliatonRoleStore"到"Microsoft.AspNet.Identity[IRole"的隐式引用转换。
错误2类型"MyNamespace.Data.ApplictonUserStore"不能用作泛型类型或方法"Microsoft.AspNet.Identity.IUserStore"中的类型参数"TUser"。没有从"MyNamespace.Data.AppliftonUserStore"到"Microsoft.AspNet.IUser"的隐式引用转换。
错误3类型"MyNamespace.Data.ApplictonUserStore"不能用作泛型类型或方法"Microsoft.AspNet.Identity.IUserStore"中的类型参数"TUser"。没有从"MyNamespace.Data.AppliftonUserStore"到"Microsoft.AspNet.IUser"的隐式引用转换。
错误4类型"Microsoft.AspNet.Identity.EntityFramework.RoleStore"不能用作泛型类型或方法"Ninject.Syntax.IBindingToSyntax.To()"中的类型参数"TImplementation"。没有从"Microsoft.AspNet.Identity.FentityFramework.LoleStore"到"Microsoft.AspNet.Identity.IRoleStore"的隐式引用转换。
错误1类型"Microsoft.AspNet.Identity.EntityFramework.UserStore"不能用作泛型类型或方法"Ninject.Syntax.IBindingToSyntax.To()"中的类型参数"TIimplementation"。没有从"Microsoft.AspNet.Identity.UentityFramework/UserStore"到"Microsoft.AspNet.Identity.IUserStore"的隐式引用转换。
默认情况下,asp.net-identity
系统使用guid作为主键。我改为使用int。我可以看到一些关于Microsoft.AspNet.Identity.IRole<string>
的错误。
编辑:这些是类别:
public class ApplicationRoleStore : RoleStore<ApplicationRole, int, ApplicationUserRole>
{
public ApplicationRoleStore(ApplicationDbContext context)
: base(context)
{ }
}
public class ApplicationUserStore :
UserStore<ApplicationUser, ApplicationRole, int, ApplicationUserLogin, ApplicationUserRole, ApplicationUserClaim>
{
public ApplicationUserStore(ApplicationDbContext context)
: base(context)
{ }
}
我想明白了。如果其他人无意中发现了这一点,以下是方法:
kernel.Bind<IAuthenticationManager>().ToMethod(c => HttpContext.Current.GetOwinContext().Authentication); //.InRequestScope();
kernel.Bind<IRoleStore<ApplicationRole, int>>().To<RoleStore<ApplicationRole, int, ApplicationUserRole>>()
.WithConstructorArgument("context", context => kernel.Get<ApplicationDbContext>());
kernel.Bind<IUserStore<ApplicationUser, int>>()
.To<UserStore<ApplicationUser, ApplicationRole, int, ApplicationUserLogin, ApplicationUserRole, ApplicationUserClaim>>()
.WithConstructorArgument("context", context => kernel.Get<ApplicationDbContext>());
不确定IAuthenticationManager
是否应该是InRequestScope
,但现在我忽略了那个部分。
对于经理来说,你会这样做:
kernel.Bind<UserManager<ApplicationUser, int>>().ToSelf().InRequestScope();
kernel.Bind<RoleManager<ApplicationRole, int>>().ToSelf().InRequestScope();