Как стать автором
Обновить

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

читаешь читаешь статью, про конфигурации, настройки, как правильно делать.
И на тебе ляп в конце статьи " Console.WriteLine(" :DD
Console.WriteLine — используется только для демонстрации работы шаблона, показать максимально наглядно как это работает. Можно было использовать ILog, добавить зависимости, но это только усложнило бы пример. Тем более в ILog ничего сложного нет, и Console.WriteLine легко заменить соответствующие методы из ILog.
В файле Startup.cs заменим:

В предыдущих примерах при отсутствии файла appsettings.json приложение выбросит исключение

Если для создания хоста приложения (в файле Program.cs) используется метод CreateDefaultBuilder, то файл «appsettings.json» уже добавлен с опциями «optional: true» и «reloadOnChange: true»:

Исходный код метода CreateDefaultBuilder
public static IWebHostBuilder CreateDefaultBuilder(string[] args)
{
  var builder = new WebHostBuilder();

  if (string.IsNullOrEmpty(builder.GetSetting(WebHostDefaults.ContentRootKey)))
  {
    builder.UseContentRoot(Directory.GetCurrentDirectory());
  }
  if (args != null)
  {
    builder.UseConfiguration(new ConfigurationBuilder().AddCommandLine(args).Build());
  }

  builder.ConfigureAppConfiguration((hostingContext, config) =>
  {
    var env = hostingContext.HostingEnvironment;

    config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
        .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true);

    if (env.IsDevelopment())
    {
      var appAssembly = Assembly.Load(new AssemblyName(env.ApplicationName));
      if (appAssembly != null)
      {
        config.AddUserSecrets(appAssembly, optional: true);
      }
    }

    config.AddEnvironmentVariables();

    if (args != null)
    {
      config.AddCommandLine(args);
    }
  })
  .ConfigureLogging((hostingContext, loggingBuilder) =>
  {
    loggingBuilder.Configure(options =>
    {
      options.ActivityTrackingOptions = ActivityTrackingOptions.SpanId
                        | ActivityTrackingOptions.TraceId
                        | ActivityTrackingOptions.ParentId;
    });
    loggingBuilder.AddConfiguration(hostingContext.Configuration.GetSection("Logging"));
    loggingBuilder.AddConsole();
    loggingBuilder.AddDebug();
    loggingBuilder.AddEventSourceLogger();
  }).
  UseDefaultServiceProvider((context, options) =>
  {
    options.ValidateScopes = context.HostingEnvironment.IsDevelopment();
  });

  ConfigureWebDefaults(builder);

  return builder;
}



github.com/dotnet/aspnetcore/blob/7e9e03b70124784b1de5564c573bd65cdaccbfcc/src/DefaultBuilder/src/WebHost.cs#L173
Как бы в Startup.cs строится новая конфигурация, и потом идет замена предыдущей, поэтому все верно.
Замена конфигурации: configuration = builder.Build();
public Startup(IConfiguration configuration)
  {
     var builder = new ConfigurationBuilder()
       .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true);
     configuration = builder.Build();
     Configuration = configuration;
  }

А это вообще сработает? Имею ввиду тот IConfiguration который приходит в Startup он же c ServiceProvider идет, разве замена его в Startup изменит его в ServiceProvider?
Зарегистрируйтесь на Хабре , чтобы оставить комментарий

Публикации