ASP.NET Core配置文件的獲取和設(shè)置
在ASP.NET Core 中,應(yīng)用程序配置數(shù)據(jù)可以使用JSON, XML 和 INI格式 和內(nèi)置環(huán)境變量,命令行參數(shù)或內(nèi)存中的集合。
1.如何獲取和設(shè)置配置
ASP.NET Core配置系統(tǒng)針對(duì)以前的依賴于System.Configuration和XML配置文件(如Web.config)的ASP,NET 版本進(jìn)行了重構(gòu)。新的配置模型提供了精簡(jiǎn)高效的,能夠通過(guò)檢索多樣化提供程序來(lái)獲取基于鍵/值對(duì)配置的能力。應(yīng)用程序和框架可以通過(guò)新的選擇模式訪問(wèn)配置。
可以在ASP.NET Core應(yīng)用程序中的Startup類中只實(shí)例化一個(gè)Configuration示例,然后選擇模式來(lái)訪問(wèn)各自的設(shè)置。
Configuration類是一個(gè)提供讀寫鍵/值對(duì)能力的Providers集合。如果一個(gè)鍵值對(duì)寫入Configuration,它不會(huì)持久,當(dāng)源再次讀寫值時(shí)將會(huì)丟失。因此至少需要配置一個(gè)數(shù)據(jù)源,使得configuration能正常工作。
下面通過(guò)內(nèi)存配置演示Configuration處理鍵值對(duì):

內(nèi)存配置一般用在一次請(qǐng)求中需要暫存數(shù)據(jù)的情況,例如,如果管道中有多個(gè)中間件,可以在某一個(gè)中間件中暫存數(shù)據(jù),后面的某一個(gè)中使用。
在開(kāi)發(fā)中一般會(huì)把配置值放在一個(gè)有層次的數(shù)據(jù)結(jié)構(gòu)中,例如appsettings.json,在這種情況下,可以使用以: 符號(hào)分割(從層次結(jié)構(gòu)的根開(kāi)始)的鍵讀取值:
{
"ConnectionStrings": {
"DefaultConnection": "Data Source=.;Initial Catalog=AccessManagement;Integrated Security=True"
},
"Logging": {
"LogLevel": {
"Default": "Information"
}
},
"AllowedHosts": "*",
"MyOptions": {
"Option1": "ww",
"Option2": 3
}
}在應(yīng)用程序中通過(guò)Configuration獲取配置的連接字符串,可以通過(guò)ConnectionStrings:DefaultConnection讀取ConnectionStrings的設(shè)置,也可以通過(guò)GetConnectionString擴(kuò)展方法加參數(shù)"DefaultConnection"來(lái)獲取。

應(yīng)用程序所需要的設(shè)置和指定配置的機(jī)制都可以通過(guò)使用選擇模式解耦。創(chuàng)建自己的配置類時(shí),可以是幾個(gè)不同的類,分別對(duì)應(yīng)不同的配置組,然后通過(guò)選項(xiàng)服務(wù)注入到應(yīng)用程序中。這樣就可以通過(guò)配置或其他所選擇的機(jī)制來(lái)設(shè)置了。
2.使用內(nèi)置數(shù)據(jù)源
開(kāi)發(fā)時(shí)并不局限于必須使用單個(gè)配置提供程序,可以把多個(gè)配置提供程序組合在一起。
擴(kuò)展方法支持為配置添加額外的配置文件提供程序。這些方法能被獨(dú)立的或鏈?zhǔn)秸{(diào)用在ConfigurationBuilder實(shí)例之上:
public Startup()
{
var builder = new ConfigurationBuilder();
builder.SetBasePath(Directory.GetCurrentDirectory());
builder.AddJsonFile("appsettings.json");
var config = builder.Build();
var _config = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json")
.Build();
}指定配置提供程序的順序很重要,這將影響他們的設(shè)置被應(yīng)用的優(yōu)先級(jí):
public Startup(IConfiguration configuration,IHostingEnvironment env)
{
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile(“appsettings.json",optional:true,reloadOnChange:true)
.AddJsonFile($"appsettings.{env.EnvironmentName}.json",optional:true);
//配置環(huán)境變量
builder.AddEnvironmentVariables();
Configuration = builder.Build();
}
public IConfiguration Configuration { get; }IHostingEnvironment 服務(wù)用于獲取當(dāng)前環(huán)境。在Development環(huán)境中,AddJsonFile($"appsettings.{env.EnvironmentName}.json",optional:true)將會(huì)查找appsettings.Development.json配置文件,并覆蓋appsettings.json中存在的值。同樣環(huán)境變量也會(huì)覆蓋它們兩個(gè)的值。
一旦將指定文件作為配置源,就可以選擇當(dāng)文件發(fā)生變化后,是否重新再付這部分的配置,reloadOnChange:true。
3.使用選項(xiàng)和配置對(duì)象
選擇模式可使用自定義的配置類表示一組相關(guān)設(shè)置。這個(gè)配置類需要為配置項(xiàng)提供公開(kāi)的 屬性和一個(gè)無(wú)參的構(gòu)造函數(shù)??梢愿鶕?jù)應(yīng)用程序的功能分解為多個(gè)配置對(duì)象。
下面自定義appsettings.json的配置類,并使用:
先創(chuàng)建配置類
namespace MVCTest
{
public class AppSettingOptions
{
public DefaultConnec ConnectionStrings { get; set; }
public string AllowedHosts { get; set; }
}
public class DefaultConnec
{
public string DefaultConnection { get; set; }
}
}在ConfigureServices中調(diào)用選項(xiàng)服務(wù):
public Startup(IConfiguration configuration,IHostingEnvironment env)
{
//Configuration = configuration;
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json",optional:true,reloadOnChange:true)
//.AddJsonFile($"appsettings.{env.EnvironmentName}.json",optional:true);
//配置環(huán)境變量
builder.AddEnvironmentVariables();
Configuration = builder.Build();
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
services.AddOptions();//提供依賴注入
services.Configure<AppSettingOptions>(Configuration); //綁定配置選項(xiàng)
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
}在HomeController中使用:
public class HomeController : Controller
{
private readonly IOptions<AppSettingOptions> _options;
public HomeController(IOptions<AppSettingOptions> options,)
{
_options = options;
}
public static Logger nlog = LogManager.GetCurrentClassLogger();
public IActionResult Index()
{
var AllowedHosts = _options.Value.AllowedHosts;
var DefaultConnection = _options.Value.ConnectionStrings.DefaultConnection;
}
}結(jié)果:

當(dāng)通過(guò)綁定選項(xiàng)來(lái)配置選項(xiàng)類型的每一個(gè)屬性時(shí),實(shí)際上是綁定到每一個(gè)配置鍵。配置鍵是大小寫不敏感的。
當(dāng)通過(guò)調(diào)用services.Configure<AppSettingOptions>(Configuration);代碼,將一個(gè)IConfigureOptions<AppSettingOptions>服務(wù)加入服務(wù)容器,是為了后面應(yīng)用程序或框架能通過(guò)IOptions<AppSettingOptions>服務(wù)來(lái)獲取配置。若想從其他途徑(從數(shù)據(jù)庫(kù)通過(guò)EF獲?。┇@取配置,可以使用ConfigureOptions<TOptions>擴(kuò)展方法直接指定經(jīng)過(guò)定制的IConfigureOptions<TOptions>服務(wù)。
其他方法:
//通過(guò)代碼編寫
services.Configure<AppSettingOptions>(options=>
{
options.AllowedHosts = "test";
});
//只配置部分
services.Configure<AppSettingOptions>(Configuration.GetSection("ConnectionStrings"));到此這篇關(guān)于ASP.NET Core配置文件的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ASP.NET MVC DropDownList數(shù)據(jù)綁定及使用詳解
DropDownList 控件用于創(chuàng)建下拉列表。DropDownList 控件中的每個(gè)可選項(xiàng)都是由 ListItem 元素定義的!該控件支持?jǐn)?shù)據(jù)綁定2012-12-12
分享Visual Studio原生開(kāi)發(fā)的10個(gè)調(diào)試技巧(2)
這篇文章又為大家分享了Visual Studio原生開(kāi)發(fā)的10個(gè)調(diào)試技巧,感興趣的朋友可以參考一下2015-11-11
asp.net 實(shí)現(xiàn)動(dòng)態(tài)顯示當(dāng)前時(shí)間(不用javascript不考慮開(kāi)銷)
asp.net實(shí)現(xiàn)動(dòng)態(tài)顯示時(shí)間,無(wú)需用到j(luò)avascrip,而是用了AJAX。2009-11-11
.NET讀寫Excel工具Spire.Xls使用 Excel文件的控制(2)
這篇文章主要為大家詳細(xì)介紹了.NET讀寫Excel工具Spire.Xls使用,Excel文件的控制,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
asp.net下String.prototype.split()的兼容問(wèn)題
IE下的String.prototype.split()函數(shù)bug2012-12-12
asp.net分頁(yè)控件AspNetPager的樣式美化
自從吳旗娃推出了AspNetPager分頁(yè)控件之后,受到了廣大程序員朋友的喜愛(ài),無(wú)數(shù)個(gè)網(wǎng)站都出現(xiàn)這個(gè)控件的身影??墒谴蟛糠志W(wǎng)站程序員的朋友都是直接套用,導(dǎo)致滿世界的分頁(yè)控件樣式都是一樣的簡(jiǎn)潔,傷不起啊2011-12-12

