這篇文章主要介紹ASP.NET Core怎么配置和使用環(huán)境變量,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
弋陽ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!前言
通常在應(yīng)用程序開發(fā)到正式上線,在這個過程中我們會分為多個階段,通常會有 開發(fā)、測試、以及正式環(huán)境等。每個環(huán)境的參數(shù)配置我們會使用不同的參數(shù),因此呢,在ASP.NET Core中就提供了相關(guān)的環(huán)境API,方便我們更好的去做這些事情。
環(huán)境
ASP.NET Core使用ASPNETCORE_ENVIRONMENT來標(biāo)識運(yùn)行時環(huán)境。
ASP.NET Core預(yù)設(shè)環(huán)境
Development:開發(fā)環(huán)境
Staging:暫存環(huán)境(測試環(huán)境)
Production:正式環(huán)境
要取得系統(tǒng)變量ASPNETCORE_ENVIRONMENT,在3.0版本之前可以通過注入IHostingEnvironment來獲取,3.x通過IWebHostEnvironment 請看如下代碼片段:
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()}" ); }); } }
網(wǎng)站啟動后IWebHostEnvironment會從ASPNETCORE_ENVIRONMENT中獲取內(nèi)容,該變量可以是我們需要的任何值。也就是該變量不一定要一定是預(yù)設(shè)的值,我們是可以自定義的。
比如我們定義一個名為Test環(huán)境
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { env.EnvironmentName = "test"; if (env.IsDevelopment()) { //TODO }else if (env.IsEnvironment("text")) { //TODO } app.Run(async (context) => { await context.Response.WriteAsync( $"EnvironmentName: {env.EnvironmentName},IsDevelopment: {env.IsDevelopment()}" ); }); }
注:在 Windows 和 macOS 上,環(huán)境變量和值不區(qū)分大小寫。 默認(rèn)情況下,Linux 環(huán)境變量和值要區(qū)分大小寫 。
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(); });
通過上述代碼我們,讀取我們的配置文件回顯讀取setting.json并設(shè)置為optional: false,表示該配置為必要的配置;再往下繼續(xù)讀取再讀取settings.{env.EnvironmentName}.json文件。當(dāng)加載遇到相同的Key那么就會覆蓋掉前面的配置項(xiàng)。
SetBasePath:設(shè)置配置的目錄位置,如果是放在不同目錄,再把路徑換掉即可。
AddJsonFile:
path:文件的路徑位置。
optional:如果是必要的配置文件,可選就要設(shè)定為false,當(dāng)文件不存在就會引發(fā)FileNotFoundException。
reloadOnChange:如果文件被更新,就同步更新IConfiguration實(shí)例的值。
環(huán)境設(shè)置
IIS
web.config配置環(huán)境變量
Visual Studio Code
launch.json中配置ASPNETCORE_ENVIRONMENT
{ "version": "0.1.0", "configurations": [ { "name": ".NET Core Launch (web)", "type": "coreclr", "env": { "ASPNETCORE_ENVIRONMENT": "Development" } } ] }
Visual Studio IDE
Properties\launchSettings.json
"profiles": { "IIS Express": { "commandName": "IISExpress", "launchBrowser": true, "environmentVariables": { "ASPNETCORE_ENVIRONMENT": "Test" } }, }
以上是“ASP.NET Core怎么配置和使用環(huán)境變量”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!