在ASP NET Core上启用基本身份验证-404

问题描述 投票:1回答:1

我正在使用此中间件,因为这些概念对我来说是新的

https://github.com/blowdart/idunno.Authentication/tree/master/src/idunno.Authentication.Basic

我完全按照说的那样实现了启动

但是,如果[Authorize]标识符在那里,每次我发布到WeatherForecast端点时,我都会得到一个404。我做了一些阅读,因此添加了AuthenticationSchemes但结果相同

不能是缺少的重定向,这是另一个问题,因为控制器仅在该页面中返回内容?

请有人能指出正确的方向吗?

public void ConfigureServices(IServiceCollection services)
    {
        services.AddControllers();
        services.AddMvc();
        services.AddRazorPages();
        services.AddControllersWithViews();

        services.AddAuthentication(BasicAuthenticationDefaults.AuthenticationScheme)
        .AddBasic(options =>
        {
            //options.Realm = "idunno";

            options.Events = new BasicAuthenticationEvents
            {
                OnValidateCredentials = context =>
                {
                    if (context.Username == context.Password)
                    {
                        var claims = new[]
                        {
                            new Claim(
                                ClaimTypes.NameIdentifier,
                                context.Username,
                                ClaimValueTypes.String,
                                context.Options.ClaimsIssuer),
                            new Claim(
                                ClaimTypes.Name,
                                context.Username,
                                ClaimValueTypes.String,
                                context.Options.ClaimsIssuer)
                        };

                        context.Principal = new ClaimsPrincipal(
                            new ClaimsIdentity(claims, context.Scheme.Name));
                        context.Success();
                    }

                    return Task.CompletedTask;
                }
            };
        });
    }

然后这个

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        else
        {
            app.UseExceptionHandler("/Home/Error");
            // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
            app.UseHsts();
        }
        app.UseAuthentication();
        app.UseAuthorization();
        app.UseHttpsRedirection();
        app.UseStaticFiles();
        app.UseRouting();
        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllerRoute(
                name: "default",
                pattern: "{controller=Home}/{action=Index}/{id?}");
        });
    }

控制器看起来像这样:

[Route("[controller]")]
[Authorize(AuthenticationSchemes = idunno.Authentication.Basic.BasicAuthenticationDefaults.AuthenticationScheme)]
public class WeatherForecastController : ControllerBase
{
    [HttpGet]
    public ActionController<WeatherForecast> Get()
    {
        return Content("Authorised"); 
    }
}
asp.net-core basic-authentication
1个回答
0
投票

根据注释,某些命令顺序错误

© www.soinside.com 2019 - 2024. All rights reserved.