首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Owin不返回UserManager

Owin不返回UserManager
EN

Stack Overflow用户
提问于 2015-10-11 12:03:07
回答 1查看 883关注 0票数 0

在控制器操作中调用了以下内容:

代码语言:javascript
复制
private ApplicationUserManager ApplicationUserManager
    => HttpContext.GetOwinContext().GetUserManager<ApplicationUserManager>();

我的IdentityConfig看起来像:

代码语言:javascript
复制
internal class IdentityConfig
{
    public void Configuration(IAppBuilder appBuilder)
    {
        appBuilder.CreatePerOwinContext(ApplicationIdentityDbContext.Create);
        appBuilder.CreatePerOwinContext<ApplicationUserManager>(ApplicationUserManager.Create);
        appBuilder.CreatePerOwinContext<ApplicationRoleManager>(ApplicationRoleManager.Create);

        var cookieAuthenticationOptions = new CookieAuthenticationOptions
                                          {
                                              AuthenticationType =
                                                  DefaultAuthenticationTypes
                                                  .ApplicationCookie,
                                              LoginPath =
                                                  new PathString("/Home/Login")
                                          };
        appBuilder.UseCookieAuthentication(cookieAuthenticationOptions);
    }
}

我可以逐步了解并看到这个配置被调用了,并且Create方法被调用了,并且没有返回null

代码语言:javascript
复制
public static ApplicationUserManager Create(IdentityFactoryOptions<ApplicationUserManager> options,
                                                IOwinContext context)
{
    var db = context.Get<ApplicationIdentityDbContext>();
    var manager = new ApplicationUserManager(new UserStore<ApplicationUser>(db));
    manager.PasswordValidator = new PasswordValidator();

    return manager;
}

但是,当我得到ApplicationUserManager时,它是空的。

代码语言:javascript
复制
public class AccountController : Controller
{
    private ApplicationUserManager ApplicationUserManager
        => HttpContext.GetOwinContext().GetUserManager<ApplicationUserManager>();

    [HttpPost]
    [AllowAnonymous]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> Login(LoginViewModel model, string returnUrl)
    {
        var user = await ApplicationUserManager.FindAsync(model.Username, model.Password);  // <- Null reference exception

        // ...
    }
}

我在这里错过了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-11 12:50:25

这是一个不能令人满意的办法。

卸载所有与Owin和Identity相关的Nuget包,注释掉所有未构建的内容,然后重新启动Visual,清理和重新构建,然后重新安装软件包。

当它们被安装时,由于某些原因,它们不是最新的,所以您需要返回并升级它们。

现在,再取消所有的评论,重建。突然,起作用了!

不是一个好的解决办法。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33064739

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档