ASP.NET Core使用环境变量

前言

通常在应用程序开发到正式上线,在这个过程中我们会分为多个阶段,通常会有 开发、测试、以及正式环境等。每个环境的参数配置我们会使用不同的参数,因此呢,在ASP.NET Core中就提供了相关的环境API,方便我们更好的去做这些事情。

环境

ASP.NET Core使用ASPNETCORE_ENVIRONMENT来标识运行时环境。

  • ASP.NET Core预设环境
  1. Development:开发环境
  2. Staging:暂存环境(测试环境)
  3. Production:正式环境

要取得系统变量ASPNETCORE_ENVIRONMENT,在3.0版本之前可以通过注入IHostingEnvironment来获取,3.x通过IWebHostEnvironment 请看如下代码片段:

代码语言:javascript
复制
    public class Startup
    {
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
            }
        app.Run(async (context) =>
        {
            await context.Response.WriteAsync(
                $"EnvironmentName: {env.EnvironmentName},IsDevelopment: {env.IsDevelopment()}"
            );
        });
    }
}</code></pre></div></div><p>网站启动后IWebHostEnvironment会从ASPNETCORE_ENVIRONMENT中获取内容,该变量可以是我们需要的任何值。也就是该变量不一定要一定是预设的值,我们是可以自定义的。</p><p>比如我们定义一个名为Test环境</p><div class="rno-markdown-code"><div class="rno-markdown-code-toolbar"><div class="rno-markdown-code-toolbar-info"><div class="rno-markdown-code-toolbar-item is-type"><span class="is-m-hidden">代码语言:</span>javascript</div></div><div class="rno-markdown-code-toolbar-opt"><div class="rno-markdown-code-toolbar-copy"><i class="icon-copy"></i><span class="is-m-hidden">复制</span></div></div></div><div class="developer-code-block"><pre class="prism-token token line-numbers language-javascript"><code class="language-javascript" style="margin-left:0">      public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        env.EnvironmentName = &#34;test&#34;;

        if (env.IsDevelopment())
        {
            //TODO
        }else if (env.IsEnvironment(&#34;text&#34;))
        {
            //TODO
        }

        app.Run(async (context) =&gt;
        {
            await context.Response.WriteAsync(
                $&#34;EnvironmentName: {env.EnvironmentName},IsDevelopment: {env.IsDevelopment()}&#34;
            );
        });

}

代码语言:javascript
复制
注:在 Windows 和 macOS 上,环境变量和值不区分大小写。 默认情况下,Linux 环境变量和值要区分大小写 。
代码语言:javascript
复制
        public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureAppConfiguration((hostContext, config) =>
{
var env = hostContext.HostingEnvironment;
config.SetBasePath(Path.Combine(env.ContentRootPath, "Configuration"))
.AddJsonFile(path: "settings.json", optional: false, reloadOnChange: true)
.AddJsonFile(path: $"settings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true);
})
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
});

通过上述代码我们,读取我们的配置文件回显读取setting.json并设置为optional: false,表示该配置为必要的配置;再往下继续读取再读取settings.{env.EnvironmentName}.json文件。当加载遇到相同的Key那么就会覆盖掉前面的配置项。

  • SetBasePath:设置配置的目录位置,如果是放在不同目录,再把路径换掉即可。
  • AddJsonFile:
    • path:文件的路径位置。
    • optional:如果是必要的配置文件,可选就要设定为false,当文件不存在就会引发FileNotFoundException。
    • reloadOnChange:如果文件被更新,就同步更新IConfiguration实例的值。

环境设置

  • IIS

web.config配置环境变量

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified" />
</handlers>
<aspNetCore processPath="dotnet" arguments=".\Demo.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout">
<environmentVariables>
<environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Test" />
</environmentVariables>
</aspNetCore>
</system.webServer>
</configuration>
  • Visual Studio Code

launch.json中配置ASPNETCORE_ENVIRONMENT

代码语言:javascript
复制
{
"version": "0.1.0",
"configurations": [
{
"name": ".NET Core Launch (web)",
"type": "coreclr",
"env": {
"ASPNETCORE_ENVIRONMENT": "Development"
}
}
]
}
  • Visual Studio IDE

Properties\launchSettings.json

代码语言:javascript
复制
  "profiles": {
"IIS Express": {
"commandName": "IISExpress",
"launchBrowser": true,
"environmentVariables": {
"ASPNETCORE_ENVIRONMENT": "Test"
}
},
}