Я реализовал Asp.Net Identity ApplicationManager с помощью ninject. Я ссылаюсь на эту ссылку Как добавить UserManager & SignInManager , когда я выполняю свой код.
Но когда я пытаюсь сбросить свой пароль, появляется сообщение «IUserTokenProvider не зарегистрирован».
Потому что мои IdentityFactoryOptions являются нулевыми.
Как я могу ввести его в Ninject?
Проблема в том, что dataProtectionProvider всегда имеет значение
if (dataProtectionProvider != null)
{
this.UserTokenProvider =
new DataProtectorTokenProvider<ApplicationUser, int>(dataProtectionProvider.Create("ASP.NET Identity"));
}
private static void RegisterServices(IKernel kernel)
{
...
kernel.Bind<IUserStore<ApplicationUser,int>>().To<ApplicationUserStore>();
kernel.Bind<UserManager<ApplicationUser,int>>().ToSelf();
kernel.Bind<HttpContextBase>().ToMethod(ctx => new HttpContextWrapper(HttpContext.Current)).InTransientScope();
kernel.Bind<ApplicationSignInManager>().ToMethod((context) =>
{
var cbase = new HttpContextWrapper(HttpContext.Current);
return cbase.GetOwinContext().Get<ApplicationSignInManager>();
});
kernel.Bind<ApplicationUserManager>().ToSelf();
kernel.Bind<IUserService>().To<ApplicationUserManager>().InRequestScope();
...
}
public ApplicationUserManager(ApplicationUserStore store,
IdentityFactoryOptions<ApplicationUserManager> options) : base(store)
{
_store = store;
this.UserValidator = new UserValidator<ApplicationUser, int>(this)
{
AllowOnlyAlphanumericUserNames = false,
RequireUniqueEmail = false,
};
// Configure validation logic for passwords
this.PasswordValidator = new PasswordValidator
{
RequiredLength = 4,
RequireNonLetterOrDigit = false,
RequireDigit = false,
RequireLowercase = false,
RequireUppercase = false,
};
// Configure user lockout defaults
this.UserLockoutEnabledByDefault = true;
this.DefaultAccountLockoutTimeSpan = TimeSpan.FromMinutes(5);
this.MaxFailedAccessAttemptsBeforeLockout = 10;
// Register two factor authentication providers. This application uses Phone and Emails as a step of receiving a code for verifying the user
// You can write your own provider and plug in here.
this.RegisterTwoFactorProvider("PhoneCode", new PhoneNumberTokenProvider<ApplicationUser, int>
{
MessageFormat = "Your security code is: {0}"
});
this.RegisterTwoFactorProvider("EmailCode", new EmailTokenProvider<ApplicationUser, int>
{
Subject = "SecurityCode",
BodyFormat = "Your security code is {0}"
});
var dataProtectionProvider = options.DataProtectionProvider;
//dataProtectionProvider is always null
if (dataProtectionProvider != null)
{
this.UserTokenProvider =
new DataProtectorTokenProvider<ApplicationUser, int>(dataProtectionProvider.Create("ASP.NET Identity"));
}
}