Как отключить аутентификацию во время запуска приложения Blazor B2C?

Я создал серверное приложение ASP.NET 5 Blazor с входом B2C. Ниже приведен код запуска. Когда я запускаю приложение, я вижу, что открывается страница входа B2C. Как я могу предотвратить аутентификацию при запуске? Я хочу, чтобы пользователь вошел в систему, щелкнув ссылку Вход только в верхнем меню.

    {
        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.
        // For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddAuthentication(OpenIdConnectDefaults.AuthenticationScheme)
                .AddMicrosoftIdentityWebApp(Configuration.GetSection("AzureAdB2C"));

            services.AddControllersWithViews()
                .AddMicrosoftIdentityUI();

            services.AddAuthorization(options =>
            {
                // By default, all incoming requests will be authorized according to the default policy
                options.FallbackPolicy = options.DefaultPolicy;
            });

            services.AddRazorPages();
            services.AddServerSideBlazor()
                .AddMicrosoftIdentityConsentHandler();

            services.AddSingleton<WeatherForecastService>();
        }

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

            app.UseAuthentication();
            app.UseAuthorization();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
                endpoints.MapBlazorHub();
                endpoints.MapFallbackToPage("/_Host");
            });
        }
    }

person wonderful world    schedule 01.03.2021    source источник


Ответы (1)


Я проверил ваш код, и похоже, что options.FallbackPolicy = options.DefaultPolicy; вызывает автоматическое перенаправление. Прокомментируйте это и попробуйте, это должно сработать. Я также создал приложение ASP .NET Core 5 Blazor Server и протестировал этот фрагмент кода. Прокомментировав указанную выше строку, я получаю доступную для пользователя кнопку входа в систему, чтобы щелкнуть по ней.

services.AddControllersWithViews()
                .AddMicrosoftIdentityUI();

            services.AddAuthorization(options =>
            {
                // By default, all incoming requests will be authorized according to the default policy
                //options.FallbackPolicy = options.DefaultPolicy;
            });
person SouravMishra-MSFT    schedule 02.03.2021
comment
Решение не сработало. Приложение по-прежнему перенаправляется на страницу входа в B2C. Обратите внимание, что мое приложение - это серверное приложение Blazor, созданное с помощью ASP.NET Core 5. - person wonderful world; 02.03.2021
comment
Обновлен приведенный выше комментарий. Попробуйте и дайте нам знать, если это сработает. - person SouravMishra-MSFT; 02.03.2021
comment
Решение сработало. - person wonderful world; 02.03.2021