Политика авторизации Asp.Net Core 2.1 не является обработчиком триггера - PullRequest
0 голосов
/ 22 октября 2019

У меня очень простой веб-сайт .net core 2.1 (используется проверка подлинности Windows), политика на контроллере не запускает обработчик, когда я использую отдельные классы для требования и обработчика, но работает, если я объединяю 2 класса. Глядя на пример, это должно быть очень просто, но по какой-то причине это не сработает.

Буду признателен за любые предложения. Мой код показан ниже

Требование и обработчик

using Microsoft.AspNetCore.Authorization;
using System.Threading.Tasks;
namespace WebApplication4
{
    public class TestRequirement : IAuthorizationRequirement
    {
        public TestRequirement(){ }
    }
    // Break point in Handler never hit
    public class TestHandler : AuthorizationHandler<TestRequirement>
    {

        public TestHandler(){}
        protected override Task HandleRequirementAsync(AuthorizationHandlerContext context, TestRequirement requirement)
        {
            context.Succeed(requirement);
            return Task.CompletedTask;
        }
    }
    // Merged Requirement & Handler works
    public class RequirementPlusHandler : IAuthorizationHandler, IAuthorizationRequirement
    {
        public RequirementPlusHandler(){ }
        public Task HandleAsync(AuthorizationHandlerContext context)
        {
            context.Succeed(this);
            return Task.CompletedTask;
        }
    }
}

Запуск

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;

namespace WebApplication4
{
    public class Startup
    {
        public Startup(IConfiguration configuration){Configuration = configuration;}
        public IConfiguration Configuration { get; }
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddAuthentication(Microsoft.AspNetCore.Server.IISIntegration.IISDefaults.AuthenticationScheme); // Causes a 403 page to show if no access
            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
            services.AddAuthorization(options =>
            {
                options.AddPolicy("Test", policy =>
                {
                    policy.AddRequirements(new TestRequirement()); // Not work
                    //policy.AddRequirements(new RequirementPlusHandler()); // Works
                });
            }); 
         }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            app.UseAuthentication(); // Just added but not fix
            app.UseDeveloperExceptionPage();
            app.UseHttpsRedirection();
            app.UseStaticFiles();
            app.UseCookiePolicy();


            app.UseMvc(routes =>
            {
                routes.MapRoute(
                    name: "default",
                    template: "{controller=Home}/{action=Index}/{id?}");
            });
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...