Невозможно получить UserManager из OwinContext в API-контроллере
-
20-12-2019 - |
Вопрос
Я следую образцу Microsoft для реализации проверки электронной почты с помощью Identity 2.0.0.
Я застрял на этой части
public ApplicationUserManager UserManager
{
get
{
return _userManager ?? HttpContext.GetOwinContext().GetUserManager<ApplicationUserManager>();
}
private set
{
_userManager = value;
}
}
Это работает в controller
но HttpContext
не содержит никаких GetOwinContext
метод в Апиконтроллер.
Поэтому я попробовал HttpContext.Current.GetOwinContext()
но метод GetUserManager
не существует.
Я не могу придумать, как получить UserManager
я встраиваю Запуск.Auth.cs
// For more information on configuring authentication, please visit http://go.microsoft.com/fwlink/?LinkId=301864
public void ConfigureAuth(IAppBuilder app)
{
//Configure the db context, user manager and role manager to use a single instance per request
app.CreatePerOwinContext(ApplicationDbContext.Create);
app.CreatePerOwinContext<ApplicationUserManager>(ApplicationUserManager.Create);
...
}
эта линия
app.CreatePerOwinContext<ApplicationUserManager>(ApplicationUserManager.Create);
вызывает следующую функцию для настройки UserManager
public static ApplicationUserManager Create(IdentityFactoryOptions<ApplicationUserManager> options, IOwinContext context)
{
var manager = new ApplicationUserManager(new UserStore<ApplicationUser>(context.Get<ApplicationDbContext>()));
//Configure validation logic for usernames
manager.UserValidator = new UserValidator<ApplicationUser>(manager)
{
AllowOnlyAlphanumericUserNames = false,
RequireUniqueEmail = true
};
// Configure user lockout defaults
manager.UserLockoutEnabledByDefault = true;
manager.DefaultAccountLockoutTimeSpan = TimeSpan.FromMinutes(5);
manager.MaxFailedAccessAttemptsBeforeLockout = 5;
manager.EmailService = new EmailService();
var dataProtectionProvider = options.DataProtectionProvider;
if (dataProtectionProvider != null)
{
manager.UserTokenProvider = new DataProtectorTokenProvider<ApplicationUser>(dataProtectionProvider.Create("ASP.NET Identity"));
}
return manager;
}
Как я могу получить к этому доступ UserManager
в ApiController
?
Решение
Я действительно неправильно понял ваш вопрос ранее.Я думаю, вам просто не хватает некоторых операторов использования.
А GetOwinContext().GetUserManager<ApplicationUserManager>()
в Microsoft.AspNet.Identity.Owin
.
Итак, попробуйте добавить эту часть:
using Microsoft.AspNet.Identity.Owin;
using Microsoft.AspNet.Identity; // Maybe this one too
var manager = HttpContext.Current.GetOwinContext().GetUserManager<UserManager<User>>();
Другие советы
Этот метод расширения может быть лучшим решением, если вы хотите провести модульное тестирование своих контроллеров.
using System;
using System.Net.Http;
using System.Web;
using Microsoft.Owin;
public static IOwinContext GetOwinContext(this HttpRequestMessage request)
{
var context = request.Properties["MS_HttpContext"] as HttpContextWrapper;
if (context != null)
{
return HttpContextBaseExtensions.GetOwinContext(context.Request);
}
return null;
}
Использование:
public ApplicationUserManager UserManager
{
get
{
return _userManager ?? Request.GetOwinContext().GetUserManager<ApplicationUserManager>();
}
private set
{
_userManager = value;
}
}
Эта единственная строка кода спасла мой день...
var manager =
new ApplicationUserManager(new UserStore<ApplicationUser>(new ApplicationDbContext()));
Вы можете использовать его в действии контроллера, чтобы получить экземпляр UserManager.