asp.net core中靈活的配置方式詳解
前言
asp.net core支持外部文件和命令行參數(shù)方式來配置系統(tǒng)運(yùn)行所需要的配置信息,我們從下面兩個(gè)常用場景來具體說下具體使用方法。
一、監(jiān)聽地址及端口配置
1,命令行方式
asp.net core系統(tǒng)通過命令行方式啟動(dòng),使用的命令如下:
dotnet run
上面的命令直接在源代碼目錄下執(zhí)行,便可以編譯程序并運(yùn)行。那對于已經(jīng)發(fā)布好的程序,就不能使用上面的指令了,應(yīng)該使用下面的指令:
dotnet 程序集文件名(程序集文件名就是程序發(fā)布后生成的dll文件)
上面兩個(gè)指令都能夠啟動(dòng)應(yīng)用程序。程序啟動(dòng)后,默認(rèn)監(jiān)聽地址及端口是http://localhost:5000。但是程序發(fā)布后,肯定不會(huì)使用默認(rèn)的地址及端口,那如果要想讓啟動(dòng)時(shí)監(jiān)聽其他的地址或域名怎么辦?答案是使用--urls參數(shù),具體指令格式如下:
dotnet run --urls="http://域名:端口號(hào)"
如果想設(shè)置多個(gè)域名,可以使用分號(hào)分隔。
程序默認(rèn)情況下是不支持參數(shù)傳遞的,我們需要對程序進(jìn)行一些配置。首先需要引入Microsoft.Extensions.Configuration.CommandLine
庫文件,然后在main方法中添加commandline支持,具體代碼如下:
public class Program { public static void Main(string[] args) { var config = new ConfigurationBuilder() .AddCommandLine(args)//增加commandline支持 .Build(); var host = new WebHostBuilder() .UseConfiguration(config) .UseKestrel() .UseContentRoot(Directory.GetCurrentDirectory()) .UseIISIntegration() .UseStartup<Startup>() .UseApplicationInsights() .Build(); host.Run(); } }
經(jīng)過配置后就可以使用上面的指令傳遞參數(shù)了
2,配置文件
asp.net core配置信息也可以放置在一個(gè)配置文件中,系統(tǒng)啟動(dòng)時(shí)進(jìn)行加載配置文件內(nèi)容,來影響程序啟動(dòng)所需要的環(huán)境參數(shù)。我們來看一下具體操作過程。
首先我們需要引入一個(gè)庫文件"Microsoft.Extensions.Configuration.Json",然后在main方法中引入配置文件路徑信息,具體代碼如下:
public class Program { public static void Main(string[] args) { var config = new ConfigurationBuilder() .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("hosting.json") .Build(); var host = new WebHostBuilder() .UseConfiguration(config) .UseKestrel() .UseContentRoot(Directory.GetCurrentDirectory()) .UseIISIntegration() .UseStartup<Startup>() .UseApplicationInsights() .Build(); host.Run(); } }
通過上面方式,我們就增加了一個(gè)外部的hosting.json配置文件,在里面我們可以增加監(jiān)聽地址信息,內(nèi)容如下:
{ "server.urls": "http://*:5001" }
二、運(yùn)行環(huán)境配置
在進(jìn)行項(xiàng)目開發(fā)時(shí),常常要求開發(fā)環(huán)境,測試環(huán)境及正式環(huán)境的分離,并且不同環(huán)境運(yùn)行的參數(shù)都是不一樣的,比如監(jiān)聽地址,數(shù)據(jù)庫連接信息等。當(dāng)然我們把配置信息保存到一個(gè)文件中,每次發(fā)布的時(shí)候,可以先修改配置文件的內(nèi)容,然后再進(jìn)行程序發(fā)布,這樣操作起來無疑是很麻煩,每次發(fā)布都得先確定對應(yīng)的環(huán)境,然后修改配置信息,如果需要同時(shí)發(fā)布多個(gè)環(huán)境版本,那就得進(jìn)行多次操作。
asp.net core 其實(shí)已經(jīng)考慮到了這樣的場景,我們可以先看下下面的代碼:
public Startup(IHostingEnvironment env) { var builder = new ConfigurationBuilder() .SetBasePath(env.ContentRootPath) .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true) .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true) .AddEnvironmentVariables(); Configuration = builder.Build(); }
上面的代碼是出現(xiàn)在startup.cs文件中,里面首先使用AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
加載appsettings配置文件,這個(gè)文件里可以放置所有環(huán)境共享的信息,后面有一句AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true)
,env.EnvironmentName
其實(shí)就是系統(tǒng)環(huán)境,根據(jù)啟動(dòng)時(shí)設(shè)置的EnvironmentName不同,可以加載對應(yīng)的配置文件內(nèi)容。
現(xiàn)在的問題是如何去指定這個(gè)EnvironmentName?
1,通過命令行指定environment
在執(zhí)行dotnet run之前,可以先執(zhí)行以下下面的指令:
set ASPNETCORE_ENVIRONMENT
= 環(huán)境名稱,注意這里沒有引號(hào),直接把環(huán)境名稱寫成具體的值即可,比如 set ASPNETCORE_ENVIRONMNET=development
然后再執(zhí)行dotnet run
指令,這樣當(dāng)前運(yùn)行就會(huì)按照set指令中設(shè)置的環(huán)境進(jìn)行運(yùn)行
2,直接給dotnet run指令傳遞具體參數(shù)
先看直接的執(zhí)行效果:dotnet run --ASPNETCORE_ENVIRONMENT=development
具體做法:引入Microsoft.Extensions.Configuration.CommandLine
,Microsoft.Extensions.Configuration.EnvironmentVariables
庫文件,然后在main方法中增加環(huán)境參數(shù)的支持,具體代碼如下:
public class Program { public static void Main(string[] args) { var config = new ConfigurationBuilder() .AddEnvironmentVariables() .AddCommandLine(args) .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("hosting.json") .Build(); var host = new WebHostBuilder() .UseEnvironment(config["ASPNETCORE_ENVIRONMENT"]) .UseConfiguration(config) .UseKestrel() .UseContentRoot(Directory.GetCurrentDirectory()) .UseIISIntegration() .UseStartup<Startup>() .UseApplicationInsights() .Build(); host.Run(); } }
關(guān)鍵是AddEnvironmentVariables(),UseEnvironment(config["ASPNETCORE_ENVIRONMENT"])
兩處的處理。這樣我們就可以在dotnet run
指令后面增加對應(yīng)的環(huán)境參數(shù)?!?/p>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Debian 8或Debian 9(64 位)安裝 .NET Core
這篇文章主要為大家詳細(xì)介紹了Debian 8或Debian 9(64 位)安裝 .NET Core,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03.NET 6開發(fā)TodoList應(yīng)用之使用AutoMapper實(shí)現(xiàn)GET請求
我們希望接受的請求和返回的值具有以下兩點(diǎn)需要遵循的原則:每個(gè)model被且只被一個(gè)API消費(fèi);每個(gè)model里僅僅包含API發(fā)起方希望包含的必要字段或?qū)傩?。AutoMapper庫就是為了實(shí)現(xiàn)這個(gè)需求而存在的。本文將為大家介紹AutoMapper如何實(shí)現(xiàn)GET請求,需要的可以參考一下2021-12-12c#實(shí)現(xiàn)根據(jù)網(wǎng)絡(luò)IP顯示地理位置功能示例
通常都會(huì)有類似 注冊IP和最后登錄IP這兩個(gè)的字段來存儲(chǔ)用戶注冊時(shí)候的IP地址和最后登錄的IP的地址,現(xiàn)在我們就簡單的實(shí)現(xiàn)一下如標(biāo)題所示的功能2013-06-06注冊頁實(shí)現(xiàn)激活郵箱驗(yàn)證(asp.net c#)
在填寫注冊提交后,大一點(diǎn)的網(wǎng)站會(huì)有郵箱激活驗(yàn)證這一步,本文也是實(shí)現(xiàn)了一下,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04VS2015 Update2 構(gòu)建 Android 程序問題匯總
這篇文章主要介紹了VS2015 Update2 構(gòu)建 Android 程序問題匯總的相關(guān)資料,需要的朋友可以參考下2016-07-07asp.net 該行已經(jīng)屬于另一個(gè)表錯(cuò)誤的解決方法
從一個(gè)TABLE中取一行放到另一個(gè)TABLE里報(bào)錯(cuò): 該行已經(jīng)屬于另一個(gè)表。的解決辦法 用下面來個(gè)方法就OK了。2010-05-05ASP.NET Core如何添加統(tǒng)一模型驗(yàn)證處理機(jī)制詳解
這篇文章主要給大家介紹了關(guān)于ASP.NET Core如何添加統(tǒng)一模型驗(yàn)證處理機(jī)制的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2018-05-05