温莎城堡与欧文和身份



我在使用身份和温莎城堡的典型 asp.net 项目中对owin配置有问题。问题是我真的很喜欢身份和 owin 如何管理所有用户的东西,例如向登录用户发送 cookie 等,但它需要以下代码:

[assembly: OwinStartupAttribute(typeof(OwinStartUp.Startup))]
namespace OwinStartUp
{
public partial class Startup
{
    public void Configuration(IAppBuilder app)
    {
        app.CreatePerOwinContext(DbOwinHelper.CreateDbContext);
        app.CreatePerOwinContext<ApplicationUserManager>(DbOwinHelper.CreateUserManager);
        app.CreatePerOwinContext<ApplicationSignInManager>(DbOwinHelper.CreateSignInManager);                       
        app.UseCookieAuthentication(new CookieAuthenticationOptions
        {
            AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie,
            LoginPath = new PathString("/Account/Login"),
            Provider = new CookieAuthenticationProvider
            {
                OnValidateIdentity = SecurityStampValidator.OnValidateIdentity<ApplicationUserManager, MyIdentityUser, Guid>(
         validateInterval: TimeSpan.FromMinutes(30),
         regenerateIdentityCallback: (manager, user) => user.GenerateUserIdentityAsync(manager),
         getUserIdCallback: (user) => Guid.Parse(user.GetUserId()))
            }
        });
    }
}

}

所以在例如控制器中,我必须写这个:

var signInManager = HttpContext.GetOwinContext().Get<ApplicationSignInManager>();

取而代之的是这个(我更喜欢)

var signinmanager = container.Resolve<ISignInManager<IMyIdentityUser>>();

或至少

 var signinmanager = container.Resolve<ApplicationSignInManager>();

如何将温莎与欧文管道集成?或者,至少,如何在没有owin的情况下将CookieAuthentication与我的自定义应用程序登录管理器一起使用(并且无需我自己重写整个cookie身份验证)?

我看过很多关于温莎城堡作为 owin 依赖解析器的文章,但它主要是关于自托管 owin。

好的,所以将近一年后我在这里找到了答案:WebApi + Simple Injector + OWIN

有发布这篇文章:https://simpleinjector.codeplex.com/discussions/539965然后它引出这里:SimpleInjector 的 WebAPIRequest 生命周期是否包括消息处理程序?

我认为所有这 3 个问题/答案加起来都让我满意。

相关内容

  • 没有找到相关文章

最新更新