ASP.NET Core中的配置詳解
ASP.NET Core 提供了一個靈活可擴展,基于鍵值的配置系統(tǒng). 但是配置系統(tǒng)獨立于ASP.NET Core是Microsoft.Extensions 類庫的部分. 它可以用于任何類型的應(yīng)用程序
1、以鍵-值對的形式讀取配置
appsettings.json 文件:
{ "Position": { "Title": "編輯器", "Name": "Joe Smith" }, "MyKey": "My appsettings.json Value", "Logging": { "LogLevel": { "Default": "Information", "Microsoft": "Warning", "Microsoft.Hosting.Lifetime": "Information" } }, "AllowedHosts": "*" }
在ConfigureServices方法里面添加如下測試代碼:
var myKeyValue = Configuration["MyKey"]; var title = Configuration["Position:Title"]; var name = Configuration["Position:Name"]; var defaultLogLevel = Configuration["Logging:LogLevel:Default"];
2、多環(huán)境配置
使用默認(rèn)配置,EnvironmentVariablesConfigurationProvider 會在讀取 appsettings.json、appsettings.Environment.json 和機密管理器后從環(huán)境變量鍵值對加載配置 。 因此,從環(huán)境中讀取的鍵值會替代從 appsettings.json、appsettings.Environment.json 和機密管理器中讀取的值 。在 launchSettings.json 中設(shè)置的環(huán)境變量,在 launchSettings.json 中設(shè)置的環(huán)境變量將替代在系統(tǒng)環(huán)境中設(shè)置的變量。
3、讀取結(jié)構(gòu)化的配置數(shù)據(jù)
添加一個類 TestSubSectionConfig 對應(yīng)于配置文件中的 subsection 節(jié)點
public class TestSubSectionConfig { public string SubOption1 { get; set; } public string SubOption2 { get; set; } }
在ConfigureServices方法里面添加如下測試代碼:
//使用GetSection解析配置文件的節(jié) var subsectionOptions = Configuration.GetSection("subsection").Get<TestSubSectionConfig>(); var suboption2 = subsectionOptions.SubOption2; Console.WriteLine($"subsection:suboption2: {suboption2}");
如果需要在Controller里面使用,可以通過依賴注入的方式:
在ConfigureServices里面注冊配置項。
public void ConfigureServices(IServiceCollection services) { //注冊配置到服務(wù)容器 services.Configure<TestSubSectionConfig>(Configuration.GetSection("subsection")); //var subsectionOptions = Configuration.GetSection("subsection").Get<TestSubSectionConfig>(); //services.Configure<TestSubSectionConfig>(options => //{ // options.SubOption1 = subsectionOptions["suboption1"]; // options.SubOption2 = subsectionOptions["suboption2"]; // }); } public class HomeController : Controller { private TestSubSectionConfig _subSectionConfig; private ILogger<HomeController> _logger; public HomeController(IOptions<TestSubSectionConfig> option, ILogger<HomeController> logger) { _subSectionConfig = option.Value; _logger = logger; } public IActionResult Index() { _logger.LogInformation($"SubOption1: {_subSectionConfig.SubOption1}"); _logger.LogInformation($"SubOption2: {_subSectionConfig.SubOption2}"); return View(); } }
到此這篇關(guān)于ASP.NET Core中的配置詳解的文章就介紹到這了,更多相關(guān)ASP.NET Core配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 在 ASP.Net Core 中使用 MiniProfiler的方法
- ASP.NET Core MVC解決控制器同名Action請求不明確的問題
- Asp.Net Core 調(diào)用第三方Open API查詢物流數(shù)據(jù)的示例
- Asp.Net Core中創(chuàng)建多DbContext并遷移到數(shù)據(jù)庫的步驟
- 如何在Asp.Net Core中集成Refit
- ASP.NET Core WebApi版本控制的實現(xiàn)
- ASP.NET Core對不同類型的用戶進行區(qū)別限流詳解
- 詳解如何在ASP.NET Core中編寫高效的控制器
- 詳解如何在ASP.NET Core中使用IHttpClientFactory
- ASP.NET Core 使用Cookie驗證身份的示例代碼
- 如何在ASP.Net Core使用分布式緩存的實現(xiàn)
- 詳解如何在ASP.NET Core Web API中以三種方式返回數(shù)據(jù)
- 詳解如何在ASP.NET Core中使用Route特性
- 如何在Asp.Net Core中集成ABP Dapper
相關(guān)文章
ASP.NET Core項目結(jié)構(gòu)教程(4)
這篇文章主要為大家詳細(xì)介紹了ASP.NET Core項目結(jié)構(gòu),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06.NET?6開發(fā)TodoList應(yīng)用之實現(xiàn)DELETE請求與HTTP請求冪等性
這篇文章主要介紹了在.NET6開發(fā)中如何實現(xiàn)DELETE請求以及HTTP請求冪等性的,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2021-12-12