Приложение не загружает значение флага функции конфигурации приложения Azure, но загружает значения конфигурации

#c# #azure #azure-app-configuration

Вопрос:

У меня есть приложение Blazor, в котором я хочу использовать конфигурацию приложения Azure.

Я успешно настроил получение значений конфигурации, однако он не находит мой флаг функции.

Когда я вводю IConfiguration и запрашиваю значение значения конфигурации, например, таким Configuration["value"] образом, извлекаются правильные данные.
Но когда я пытаюсь проверить, включен ли мой единственный флаг функции (и это так), результат всегда false, что, как я полагаю, связано с тем, что приложение не может найти флаг функции, а не потому, что оно неправильно считывает значение (передача имени несуществующего флага функции вызывает методдля возврата «false»).

Startup.cs:

 using Microsoft.AspNetCore.Authentication.OpenIdConnect;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Identity.Web;
using Microsoft.Identity.Web.UI;
using Microsoft.FeatureManagement;

namespace OreNoAppu
{
    public class Startup
    {
        public IConfiguration Configuration { get; }

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

        // 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("AzureAd"));
            services.AddControllersWithViews().AddMicrosoftIdentityUI();

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

            services.AddRazorPages();
            services.AddServerSideBlazor().AddMicrosoftIdentityConsentHandler();
            services.AddFeatureManagement();
            services.AddAzureAppConfiguration();
        }

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

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

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

Program.cs:

 using Azure.Core;
using Azure.Identity;
using Azure.Security.KeyVault.Secrets;
using BoomiLogReader.Utility;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Hosting;
using System;

namespace OreNoAppu
{
    public class Program
    {
        public static void Main(string[] args)
        {
            InitKeyVault();
            CreateHostBuilder(args).Build().Run();
        }

        public static IHostBuilder CreateHostBuilder(string[] args) =>
            Host.CreateDefaultBuilder(args)
                .ConfigureWebHostDefaults(webBuilder =>
                    webBuilder.ConfigureAppConfiguration(config =>
                    {
                        var connection = KeyVaultReader.GetSecretValue("AzureAppConfigConnStr");
                        config.AddAzureAppConfiguration(options =>
                            options.Connect(connection).UseFeatureFlags());
                    }).UseStartup<Startup>());

        // Initialises KeyVaultReader, which is used to retrieve secrets from Azure Key Vault.
        public static void InitKeyVault()
        {
            // N'importe quoi, access to KeyVault and getting of the conn string works fine.
        }
    }
}
 

Код, который должен получать флаг:

 @using Microsoft.FeatureManagement
@inject IFeatureManager featureManager

@if (featureEnabled)
{
    <h1>Yes</h1>
}

@code
{
    bool featureEnabled = true;

    protected override async Task OnInitializedAsync()
    {
        featureEnabled = featureManager.IsEnabledAsync("OreNoFlaggu").Resu<
    }
}
 

Отлаживая, я вижу, что вызов метода «IsEnabledAsync» возвращает «false», но в конфигурации моего приложения есть флаг функции «OreNoFlaggu», который приложение успешно подключает и извлекает значения конфигурации, и указанный флаг включен.

Есть идеи, почему это не работает?

Ответ №1:

@Tessaract, у вашего флага функции есть метка в вашем хранилище настроек приложения. Если это так, пожалуйста, не забудьте передать метку при вызове UseFeatureFlags() via FeatureFlagOptions.Label .

Комментарии:

1. Ай, карумба! Мало того, что это не упоминается ни в одном из 3-4 учебников, которые я прочитал, я даже не смог найти ни одного примера или информации после прочтения вашего ответа. Хорошо, что моя первая догадка о псевдокоде оправдалась. Спасибо!

2. Согласен. Документ можно было бы улучшить.

3. Этот трюк спас и меня. При настройке приложения я обновил свои флаги функций именем метки «SomeLabelName» и использовал приведенный ниже фрагмент кода. .UseFeatureFlags(opt => { opt.Label = «SomeLabelName»; }); Спасибо @ZhenlanWang