CreateBuilder方法会按照下面的顺序提供默认配置:
这个顺序可以更改,但是不建议更改,在项目开发的时候,一般不需要再去编写配置系统的初始化代码,我们可以直接通过WebApplication的Configuration属性来读取配置。
常见的环境有开发环境、测试环境、生产环境,有时不同的环境需要进行不同的配置。
环境变量ASPNETCORE_ENVIRONMENT
的值代表了程序运行环境的名字:Development(开发环境)、Staging(测试环境)、Production(生产环境)
。如果没有设置ASPNETCORE_ENVIRONMENT则默认为生产环境。
可以通过app.Environment.EnvironmentName
读取到运行环境的名字,而且可以通过app.IsDevelopment、app.IsStaging、app.IsProduction
来判断环境。
if (app.Environment.IsDevelopment())//只有开发环境时,才支持Swagger
{
app.UseSwagger();
app.UseSwaggerUI();
}
ASP.Net Core会先从appsettings.json下加载配置,然后从appesttings.Environment.json加载配置,可以是appsettings.Development.json、appsettings.Staging.json、appsettings.Production.json。一般我们在appsettings.json下编写所有环境共有的配置,在appesttings.Environment.json中编写对应于环境的配置。
某些信息不能放到源码配置文件中,比如连接字符串,里面含有连接账号及密码等信息。.net提供一个用户机密机制允许用户将机密信息放到一个单独的JSON文件中,且该文件不放在项目中,因此不会被错误的上传的Github中。
右键项目->管理用户机密->填写配置信息。这个文件会放在系统目录中某GUID编号目录下。使用用户机密的注意事项:
在WebApplication.CreateBuilder(args);
下面添加配置语句
//在CreateBuilder方法中已经完成了配置系统的初始化,就不再需要使用service.AddOption方法来注册选项的相关服务
builder.Host.ConfigureAppConfiguration((_, configBuilder) => { //此处下划线是抛元,类似于占位符
string connStr = builder.Configuration.GetConnectionString("configServer");//在用户机密里的节点
configBuilder.AddDbConfiguration(() => new SqlConnection(connStr));
});
//需要写配置类和配置节点的绑定
builder.Services.Configure<SmtpOptions>(builder.Configuration.GetSection("Smtp"));//SmtpOptions是配置实体类