ASP.NET Coreは、https://docs.asp.net/en/latest/fundamentals/configuration.htmlに示されている新しい構成システムをサポートしています 。
このモデルは.NET Coreコンソールアプリケーションでもサポートされていますか?
そうでない場合、以前のモデルapp.config
と代替のものは何ConfigurationManager
ですか?
ASP.NET Coreは、https://docs.asp.net/en/latest/fundamentals/configuration.htmlに示されている新しい構成システムをサポートしています 。
このモデルは.NET Coreコンソールアプリケーションでもサポートされていますか?
そうでない場合、以前のモデルapp.config
と代替のものは何ConfigurationManager
ですか?
回答:
このコードスニペットを使用できます。これには、構成とDIが含まれます。
public class Program
{
public static ILoggerFactory LoggerFactory;
public static IConfigurationRoot Configuration;
public static void Main(string[] args)
{
Console.OutputEncoding = Encoding.UTF8;
string environment = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT");
if (String.IsNullOrWhiteSpace(environment))
throw new ArgumentNullException("Environment not found in ASPNETCORE_ENVIRONMENT");
Console.WriteLine("Environment: {0}", environment);
var services = new ServiceCollection();
// Set up configuration sources.
var builder = new ConfigurationBuilder()
.SetBasePath(Path.Combine(AppContext.BaseDirectory))
.AddJsonFile("appsettings.json", optional: true);
if (environment == "Development")
{
builder
.AddJsonFile(
Path.Combine(AppContext.BaseDirectory, string.Format("..{0}..{0}..{0}", Path.DirectorySeparatorChar), $"appsettings.{environment}.json"),
optional: true
);
}
else
{
builder
.AddJsonFile($"appsettings.{environment}.json", optional: false);
}
Configuration = builder.Build();
LoggerFactory = new LoggerFactory()
.AddConsole(Configuration.GetSection("Logging"))
.AddDebug();
services
.AddEntityFrameworkNpgsql()
.AddDbContext<FmDataContext>(o => o.UseNpgsql(connectionString), ServiceLifetime.Transient);
services.AddTransient<IPackageFileService, PackageFileServiceImpl>();
var serviceProvider = services.BuildServiceProvider();
var packageFileService = serviceProvider.GetRequiredService<IPackageFileService>();
............
}
}
ああ、そしてproject.jsonに追加することを忘れないでください
{
"version": "1.0.0-*",
"buildOptions": {
"emitEntryPoint": true,
"copyToOutput": {
"includeFiles": [
"appsettings.json",
"appsettings.Integration.json",
"appsettings.Production.json",
"appsettings.Staging.json"
]
}
},
"publishOptions": {
"copyToOutput": [
"appsettings.json",
"appsettings.Integration.json",
"appsettings.Production.json",
"appsettings.Staging.json"
]
},
...
}
.NET Core 2.0コンソールアプリの場合、私は次のことを行いました。
{ "myKey1" : "my test value 1", "myKey2" : "my test value 2", "foo" : "bar" }
プロジェクトがビルドされるたびにファイルを出力ディレクトリにコピーするように構成します(VSで->ソリューションエクスプローラー->ファイルを右クリック-> [プロパティ]を選択-> [詳細]-> [出力ディレクトリにコピー]-> [常にコピー]を選択)
プロジェクトに次のnugetパッケージをインストールします。
以下をProgram.cs(またはどこMain()
にあるか)に追加します。
static void Main(string[] args)
{
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json");
var configuration = builder.Build();
// rest of code...
}
次に、以下のいずれかの方法を使用して値を読み取ります。
string myKey1 = configuration["myKey1"];
Console.WriteLine(myKey1);
string foo = configuration.GetSection("foo").Value;
Console.WriteLine(foo);
詳細:https : //docs.microsoft.com/en-us/aspnet/core/fundamentals/configuration?tabs=basicconfiguration#simple-configuration
IConfigurationRoot
.NET Core 2.0でも引き続き使用できます。それは継承されますIConfiguration
が、一般的には使用されない派生ケースと見なされます。いずれにしても、コード例はコード例を含まず、混乱を避けるために更新されました。
あなたが使用している場合はMicrosoft.Extensions.Hosting
、あなたのコンソールアプリケーションとasp.netコアアプリケーションをホストする(バージョン2.1.0+)、すべての構成がで注入されHostBuilder
さんConfigureAppConfiguration
とConfigureHostConfiguration
方法。appsettings.json
と環境変数を追加する方法についてのデモは次のとおりです。
var hostBuilder = new HostBuilder()
.ConfigureHostConfiguration(config =>
{
config.AddEnvironmentVariables();
if (args != null)
{
// enviroment from command line
// e.g.: dotnet run --environment "Staging"
config.AddCommandLine(args);
}
})
.ConfigureAppConfiguration((context, builder) =>
{
var env = context.HostingEnvironment;
builder.SetBasePath(AppContext.BaseDirectory)
.AddJsonFile("appsettings.json", optional: false)
.AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)
// Override config by env, using like Logging:Level or Logging__Level
.AddEnvironmentVariables();
})
... // add others, logging, services
//;
上記のコードをコンパイルするには、次のパッケージを追加する必要があります。
<PackageReference Include="Microsoft.Extensions.Configuration" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.CommandLine" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.EnvironmentVariables" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Hosting" Version="2.1.0" />
ASPNETCORE_ENVIRONMENT
が、context.HostingEnvironment.EnvironmentName
正しく設定されません
new HostBuilder()
冗長になった後ではありませんか?HostBuilder
社内ですべてやってみませんか?
間違えた。ConfigurationBuilder
netcoreコンソールアプリケーションから新規を使用できます。
例については、https://docs.asp.net/en/latest/fundamentals/configuration.htmlを参照してください。
ただし、依存関係のインジェクションはaspnetコアにのみあり、厳密に入力された構成設定を使用して、を使用してそれらを自動的にインジェクトすることはできませんIOptions
。
Microsoft.Extensions.Options
そして、電話service.AddOptions();
ConfigureWebHostDefaults()
の例の呼び出しはオプションであり、Webアプリに対してのみであることを少し明確にすることができます。
dotnet 2.xコアコンソールアプリケーションの場合、次のようになります。
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
[...]
var configuration = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddEnvironmentVariables()
.Build();
var serviceProvider = new ServiceCollection()
.AddLogging(options => options.AddConfiguration(configuration).AddConsole())
.AddSingleton<IConfiguration>(configuration)
.AddSingleton<SomeService>()
.BuildServiceProvider();
[...]
await serviceProvider.GetService<SomeService>().Start();
ILoggerFactory、IConfigurationをに挿入できますSomeService
。
.Net Core 3.1では、次のことを行う必要があります。
static void Main(string[] args)
{
var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();
}
SeriLogを使用すると、次のようになります。
using Microsoft.Extensions.Configuration;
using Serilog;
using System;
namespace yournamespace
{
class Program
{
static void Main(string[] args)
{
var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();
Log.Logger = new LoggerConfiguration().ReadFrom.Configuration(configuration).CreateLogger();
try
{
Log.Information("Starting Program.");
}
catch (Exception ex)
{
Log.Fatal(ex, "Program terminated unexpectedly.");
return;
}
finally
{
Log.CloseAndFlush();
}
}
}
}
そして、毎日1つのファイルを生成するSerilog appsetings.jsonセクションは次のようになります。
"Serilog": {
"MinimumLevel": {
"Default": "Information",
"Override": {
"Microsoft": "Warning",
"System": "Warning"
}
},
"Using": [ "Serilog.Sinks.Console", "Serilog.Sinks.File" ],
"WriteTo": [
{
"Name": "File",
"Args": {
"path": "C:\\Logs\\Program.json",
"rollingInterval": "Day",
"formatter": "Serilog.Formatting.Compact.CompactJsonFormatter, Serilog.Formatting.Compact"
}
}
]
}
そのためにLiteWare.Configurationライブラリを使用できます。元の.NET Frameworkとよく似てConfigurationManager
おり、.NET Core / Standardで動作します。コード的には、次のような結果になります。
string cacheDirectory = ConfigurationManager.AppSettings.GetValue<string>("CacheDirectory");
ulong cacheFileSize = ConfigurationManager.AppSettings.GetValue<ulong>("CacheFileSize");
免責事項:私はLiteWare.Configurationの作成者です。
積み重ねるだけ... Feiyu Zhouの投稿に似ています。ここでは、マシン名を追加しています。
public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
WebHost.CreateDefaultBuilder(args)
.ConfigureAppConfiguration((context, builder) =>
{
var env = context.HostingEnvironment;
var hostname = Environment.MachineName;
builder.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true)
.AddJsonFile($"appsettings.{hostname}.json", optional: true, reloadOnChange: true);
builder.AddEnvironmentVariables();
if (args != null)
{
builder.AddCommandLine(args);
}
})
.UseStartup<Startup>();
}
これらのパッケージをインストールします。
コード:
static void Main(string[] args)
{
var environmentName = Environment.GetEnvironmentVariable("ENVIRONMENT");
Console.WriteLine("ENVIRONMENT: " + environmentName);
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", false)
.AddJsonFile($"appsettings.{environmentName}.json", true)
.AddEnvironmentVariables();
IConfigurationRoot configuration = builder.Build();
var mySettingsConfig = configuration.Get<MySettingsConfig>();
Console.WriteLine("URL: " + mySettingsConfig.Url);
Console.WriteLine("NAME: " + mySettingsConfig.Name);
Console.ReadKey();
}
MySettingsConfigクラス:
public class MySettingsConfig
{
public string Url { get; set; }
public string Name { get; set; }
}
Directory.GetCurrentDirectory()
代わりに使用しますAppContext.BaseDirectory
。後でハックする必要はないはずです。