.NET Core аутентификация по каждому запросу (включая js / spa) - PullRequest
1 голос
/ 29 марта 2019

У меня есть проект React внутри основного решения .NET, и я просто хочу, чтобы пользователи проходили аутентификацию, чтобы увидеть реагирующий проект / SPA.

enter image description here

После долгих исследований кажется, что это невозможно без создания некоторого кода внутри проекта React, что означает добавление защиты к JS, которой можно манипулировать в клиенте.

Я видел, что может быть возможность проходить аутентификацию при каждом запросе в .Net Core, что может быть лучшим способом. Это возможно?

Я использовал некоторый код аутентификации из других ресурсов, но получаю ошибки. это мой код startup.cs

публичный класс Startup { публичный запуск (конфигурация IConfiguration) { Конфигурация = конфигурация; }

    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.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);



        // In production, the React files will be served from this directory
        services.AddSpaStaticFiles(configuration =>
        {
            configuration.RootPath = "ClientApp/build";
        });


    }

    // 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();

        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }
        else
        {
            app.UseExceptionHandler("/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.UseHttpsRedirection();
        app.UseStaticFiles();
        app.UseSpaStaticFiles();

        // This produces a server error.
        app.Use(async (context, next) =>
        {
            if (!context.User.Identity.IsAuthenticated)
            {
                await context.ChallengeAsync("");
            }
            else
            {
                await next();
            }
        });

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

            //routes.MapSpaFallbackRoute(
            //     name: "spa-fallback",
            //     defaults: new { controller = "Home", action = "AuthorizedSpaFallBack" });
        });

        app.UseSpa(spa =>
        {
            spa.Options.SourcePath = "ClientApp";

            if (env.IsDevelopment())
            {

                spa.UseReactDevelopmentServer(npmScript: "start");
            }
        });
    }
}

Или у кого-нибудь есть другие идеи, чтобы достичь того, чего я хочу?

Спасибо

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...