本文参考微软文档:ASP.NET Core 中的配置
ASP.NET Core 中的应用程序配置是使用一个或多个配置程序提供程序执行的。
配置提供程序使用各种配置源从键值对读取配置数据:
appsettings.json
这里主要介绍使用设置文件,设置文件包含一组名称类似的文件:appsettings.json,appsettings.{Environment}.json
其中,Environment 取值可以是任意值,但是框架提供了下列三个值:
ASPNETCORE_ENVIRONMENT
设置为 Development
。DOTNET_ENVIRONMENT
和 ASPNETCORE_ENVIRONMENT
时的默认值。默认的 JsonConfigurationProvider 会按以下顺序加载配置:
appsettings.json
appsettings.{Environment}.json
:例如,appsettings.Production.json
和 appsettings.Development.json
文件。 文件的环境版本是根据 IHostingEnvironment.EnvironmentName 加载的。 appsettings.{Environment}.json
值替代 appsettings.json
中的键。 例如,默认情况下:
appsettings.Development.json
配置会覆盖在 appsettings.json
中找到的值。appsettings.Production.json
配置会覆盖在 appsettings.json
中找到的值。 例如,在将应用部署到 Azure 时。经测试,通过IDE直接启动时,使用的是appsettings.Development.json文件,而发布后的程序启动时,使用的则是 appsettings.Production.json文件。
在代码中使用配置文件
通过依赖注入的方式配置Configuration属性,然后通过GetSection方法访问键值对。
- public partial class AdminContext : DbContext
- {
- public AdminContext(IConfiguration configuration)
- {
- Configuration = configuration;
- }
- public AdminContext(DbContextOptions
options, IConfiguration configuration ) - : base(options)
- {
- Configuration = configuration;
- }
- private readonly IConfiguration Configuration;
- protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
- {
- string? host = Configuration.GetSection("DBHost").Value;
- string? port = Configuration.GetSection("DBPort").Value;
- string? userid = Configuration.GetSection("DBUser").Value;
- string? password = Configuration.GetSection("DBPasswd").Value;
- string connectString = $"host={host};port={port};database=Admin; userid={userid};password={password};";
- optionsBuilder.UseMySQL(connectString);
- }
- }