Подтвердить что ты не робот

Как имена типов аутентификации зарегистрированы в asp.net vnext

Итак, я обновляю провайдер Identity asp.net с открытым исходным кодом для MongoDB для работы с Asp.Net Identity 3.0 (aka vnext). До сих пор я мог зарегистрировать провайдера и создавать пользователей, но при использовании SignInManager, если было предоставлено правильное имя пользователя/пароля, я получаю сообщение об ошибке

InvalidOperationException: следующие типы аутентификации не были принято: Microsoft.AspNet.Identity.Application

Я отследил ошибку здесь https://github.com/aspnet/HttpAbstractions/blob/dev/src/Microsoft.AspNet.PipelineCore/DefaultHttpResponse.cs

но я не могу видеть, как имя SignInContext.Accepted добавляется в SignInContext.

Я использую версии Alpha-2 для всех библиотек vnext, которые используются в VS14 CTP2

Ниже мой Startup.cs

public void Configure(IBuilder app)
    {
        try {
            // For more information on how to configure your application, visit http://go.microsoft.com/fwlink/?LinkID=398940
            var configuration = new Configuration();
            configuration.AddJsonFile("config.json");
            configuration.AddEnvironmentVariables();

         //   app.UseLogRequests("try");
            app.UseErrorPage(ErrorPageOptions.ShowAll);
            app.UseServices(services =>
            {

                services.AddIdentity<MyUser>()
                .AddMongoDB<MyUser>(configuration.Get("Data:MongoIdentity:ConnectionString"), configuration.Get("Data:MongoIdentity:DBName"))
                .AddHttpSignIn<MyUser>();


                // Add MVC services to the services container
                services.AddMvc();
            });

            // Add static files to the request pipeline
            app.UseStaticFiles();

            app.UseMvc(routes =>
            {
                routes.MapRoute(
                    name: "default",
                    template: "{controller}/{action}/{id?}",
                    defaults: new { controller = "Home", action = "Index" });

                routes.MapRoute(
                    name: "api",
                    template: "api/{controller}/{action}",
                    defaults: new { action = "Index" });
            });

            // Add cookie-based authentication to the request pipeline
            app.UseCookieAuthentication(new CookieAuthenticationOptions
            {
                AuthenticationType = DefaultAuthenticationTypes.ApplicationCookie,
                LoginPath = new PathString("/Account/Login"),
            });
        }
        catch (Exception ex)
        {
            Console.Write(ex.ToString());
            throw;
        }
    }
4b9b3361

Ответ 1

Оказывается, у меня была настройка MVC до CookieAuthentication, поэтому AuthenticationType не был зарегистрирован в MVC, когда он пытался аутентифицировать пользователя. Поскольку MVC зависит от аутентификации, мне просто нужно было поднять ее и зарегистрировать до MVC.