Атрибут Authorize по-прежнему считается успешным, даже если пользователь не вошел в систему - PullRequest
1 голос
/ 02 ноября 2019

Добрый день, я озадачен тем, почему, хотя я использую атрибут [Authorize] на своих контроллерах, он не проверяет, вошел ли пользователь в систему и все ли проходит как успешная авторизация. Я следую основным учебным курсам по идентификации и авторизации от Microsoft, ЗДЕСЬ и ЗДЕСЬ . Мне удалось настроить базовую аутентификацию, создать пользователя, войти в систему и все такое, но авторизация просто позволяет гостю пройти, и система ложно распознает их как успешных. Я использовал Chrome для тестирования, поэтому я даже использовал приватный режим и очищал куки и кеш на тот случай, если информация была сохранена. Я полностью в замешательстве и не знаю, что еще делать.

Microsoft.AspNetCore.Authorization.DefaultAuthorizationService: Информация: авторизация прошла успешно.

Получено ли сообщение об успешной авторизации, которое я получаюв журнале консоли отладки.

Ниже приведен файл Startup.cs

 public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.Configure<CookiePolicyOptions>(options =>
            {
                // This lambda determines whether user consent for non-essential cookies is needed for a given request.
                options.CheckConsentNeeded = context => true;
                options.MinimumSameSitePolicy = SameSiteMode.None;
            });

            services.AddRazorPages();
            services.AddControllersWithViews();

            services.AddAuthorization(options =>
            {
                options.DefaultPolicy = new AuthorizationPolicyBuilder().RequireAuthenticatedUser().Build();

            });


            services.AddDbContext<DevContext>(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
            services.AddDbContext<UserContext>(options => options.UseSqlServer(Configuration.GetConnectionString("UserContextConnection")));
            services.AddIdentity<User, IdentityRole>().AddEntityFrameworkStores<UserContext>().AddDefaultTokenProviders();
            services.AddAuthentication(IISDefaults.AuthenticationScheme);




            services.ConfigureApplicationCookie(options =>
            {
                //Cokie Settings
                options.Cookie.HttpOnly = true;
                options.ExpireTimeSpan = TimeSpan.FromDays(150);
                //If the LoginPath isn't set, ASP.NET Core defaults the path to Account/Login.
                // options.LoginPath = "/Account/Login";
                // options.AccessDeniedPath = "/Account/AccessDenied";
                options.LoginPath = $"/Identity/Account/Login";
                options.LogoutPath = $"/Identity/Account/Logout";
                options.AccessDeniedPath = $"/Identity/Account/AccessDenied";
                options.SlidingExpiration = true;
            });

           // services.AddSingleton<IEmailSender, EmailSender> ();
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
                app.UseDatabaseErrorPage();
            }
            else
            {
                app.UseExceptionHandler("/Home/Error");
                app.UseHsts();
            }

            app.UseHttpsRedirection();
            app.UseStaticFiles();
            app.UseRouting();
            app.UseCookiePolicy();
            app.UseAuthentication();
            app.UseAuthorization();


            app.UseEndpoints(endpoints =>
            {
                endpoints.MapRazorPages();
                endpoints.MapControllers();
                endpoints.MapControllerRoute("default", "{controller=Home}/{action=Index}/{id?}");
                endpoints.MapDefaultControllerRoute().RequireAuthorization();
            }
            );


        }
    } 

Ниже приведен файл User.cs, оставленный пустым, поскольку в базовой демоверсии не было никаких настраиваемых полей, и он по-прежнемуработал. Поэтому я не был уверен, что это может быть проблемой.

public class User : IdentityUser
    {

    }

А это домашний контроллер с атрибутами [Authorize]

 public class HomeController : Controller
    {
        public IActionResult Index()
        {
            return View();
        }

        [Authorize]
        public IActionResult Information()
        {
            ViewData["Message"] = "Test Information Page";

            return View();
        }

        [Authorize]
        public IActionResult About()
        {
            ViewData["Message"] = "Your application description page.";

            return View();
        }
        [Authorize]
        public IActionResult Contact()
        {
            ViewData["Message"] = "Your contact page.";

            return View();
        }
        [Authorize]
        public IActionResult Privacy()
        {
            return View();
        }

        [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
        public IActionResult Error()
        {
            return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
        }
    }

1 Ответ

1 голос
/ 02 ноября 2019

Я думаю, что ваша проблема в этой строке:

services.AddAuthentication(IISDefaults.AuthenticationScheme);

Это означает, что ваше приложение будет использовать вашу учетную запись Windows для аутентификации вас, а не файл cookie, который вы создали.

Я бы изменил это на это, поскольку вы используете схему аутентификации на основе файлов cookie:

services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme) .AddCookie();

См. Руководство ниже:

https://docs.microsoft.com/en-us/aspnet/core/security/authentication/cookie?view=aspnetcore-3.0

Я бы также добавил функциональность для создания и обработки токена защиты от подделки, чтобы защитить ваше приложение от перекрестной подделки.

Обновление (решение):

В этой реализации используется идентификатор пользователякоторый уже добавлен, поэтому нет необходимости вызывать AddAuthentication ()

Аналогичная проблема с этим: github.com/aspnet/AspNetCore/issues/4656

...