網站首頁 編程語言 正文
相關文章
ASP.NET Core2.2 中的Configuration配置一
ASP.NET Core2.2 中的Configuration配置二
1.前言
ASP.NET Core在應用程序上引入Microsoft.Extensions.Configuration配置,可以支持多種方式配置,包括命令行配置、環境變量配置、文件配置、內存配置,自定義配置等等。下面我們就其中幾個配置來聊聊。
2.命令行配置
CommandLineConfigurationProvider在應用程序運行時會從(例如DOS)命令行參數鍵值加載配置。要激活命令行配置,請在ConfigurationBuilder的實例上調用AddCommandLine擴展方法。使用CreateDefaultBuilder初始化新的WebHostBuilder時會自動調用AddCommandLine。
public class Program { public static void Main(string[] args) { CreateWebHostBuilder(args).Build().Run(); } public static IWebHostBuilder CreateWebHostBuilder(string[] args) => WebHost.CreateDefaultBuilder(args) .ConfigureAppConfiguration((hostingContext, config) => { // Call other providers here and call AddCommandLine last. config.AddCommandLine(args); }).UseStartup(); }
在Program加入上述代碼并在/Home/Index視圖上添加如下代碼后發布一個Web版本掛載在IIS上。
在控制臺上輸入DOS命令行dotnet D:\Release\Core\TestWebApp.dll CommandLineKey1=value1配置鍵:CommandLineKey1,值:value1的信息,會看到如下界面信息:
根據控制臺監聽站點連接,在瀏覽器上打開其中一個,比如打開https://localhost:5001/,會看到我們配置命令行信息:
3.文件配置
FileConfigurationProvider是從文件系統加載配置的基類。以下配置為應用程序提供專用于特定文件類型:INI配置、JSON配置、XML配置。
3.1 INI配置
IniConfigurationProvider在運行時會從INI文件鍵值對加載配置。若要激活INI文件配置,請在 ConfigurationBuilder的實例上調用AddIniFile擴展方法,而冒號可用作INI文件配置中的節點分隔符。現在我們在CoreWeb根目錄下添加一個INI配置文件(命名為config):
[section0] key0=value key1=value [section1] subsection:key=value [section2:subsection0] key=value [section2:subsection1] key=value
而應用程序在構建主機時會調用ConfigureAppConfiguration以指定應用程序配置(這里我們指定config.ini文件):
public class Program { public static void Main(string[] args) { CreateWebHostBuilder(args).Build().Run(); } public static IWebHostBuilder CreateWebHostBuilder(string[] args) => WebHost.CreateDefaultBuilder(args) .ConfigureAppConfiguration((hostingContext, config) => { config.SetBasePath(Directory.GetCurrentDirectory()); config.AddIniFile( "config.ini", optional: true, reloadOnChange: true); }) .UseStartup(); }
從上述代碼可以看到IConfigurationBuilder設置了文件訪問初始路徑。Optional:文件是否可選;reloadOnChange:如果文件更改,是否應重新加載配置。而通過啟動應用程序時會看到如下配置信息:
3.2 JSON配置
JsonConfigurationProvider在運行時期間會從JSON文件鍵值對加載配置。若要激活JSON文件配置,請在ConfigurationBuilder的實例上調用AddJsonFile擴展方法。使用 CreateDefaultBuilder初始化新的WebHostBuilder時,會自動調用AddJsonFile兩次,調用該方法(AddJsonFile)來從以下文件加載配置,首先會讀取appsettings.json該文件。而應用程序啟動時是會默認調用對應的appsettings.{Environment}.json環境版本的,例如appsettings.{Environment}.json會根據IHostingEnvironment.EnvironmentName加載對應文件的環境版本(開發模式、生產模式等)。現在我們在CoreWeb根目錄下添加一個JSON配置文件(命名為config):
{ "section0": { "key0": "key0value", "key1": "key1value" }, "section1": { "key0": "key0value", "key1": "key1value" }, "section2": { "subsection0": { "key0": "sub0key0value", "key1": "sub0key1value" }, "subsection1": { "key0": "sub1key0value", "key1": "sub1key1value" } } }
而應用程序在構建主機時會調用ConfigureAppConfiguration以指定除appsettings.json和appsettings.{Environment}.json以外文件的應用程序配置(這里我們指定config.json文件):
public class Program { public static void Main(string[] args) { CreateWebHostBuilder(args).Build().Run(); } public static IWebHostBuilder CreateWebHostBuilder(string[] args) => WebHost.CreateDefaultBuilder(args) .ConfigureAppConfiguration((hostingContext, config) => { config.SetBasePath(Directory.GetCurrentDirectory()); config.AddJsonFile( "config.json", optional: true, reloadOnChange: true); }) .UseStartup(); }
而通過啟動應用程序時會看到如下配置信息:
從上述信息可以看到,在我們指定config.json文件后,IConfigurationBuilder會額外多調用一次AddJsonFile,加上前兩次AddJsonFile,一共是三次。
3.2.1GetSection、GetChildren和Exists
(1)GetSection
:IConfiguration.GetSection獲取指定配置子節。下面我們通過一個示例來了解下:
public Startup(IConfiguration configuration) { Configuration = configuration; var configSection0 = Configuration.GetSection("section0"); var configSection1 = Configuration.GetSection("section0:key0"); }
而通過啟動應用程序時會看到如下配置信息:
通過上述示例可以看到,IConfiguration.GetSection僅僅是獲取到json數據里面configSection0節點鍵和路徑,并沒有獲取到它的節點值。若要獲取section0:key0中的鍵值,請在調用GetSection時提供完整節點路徑,如獲取configSection1鍵值示例。
(2)GetChildren
:獲取指定配置樹節點。下面我們通過一個示例來了解下:
public Startup(IConfiguration configuration) { Configuration = configuration; var configSection = Configuration.GetSection("section2"); var children = configSection.GetChildren(); }
而通過啟動應用程序時會看到如下配置信息:
GetChildren獲取了指定section2節點下所有節點。
(3)Exists
:使用ConfigurationExtensions.Exists確定配置節點是否存在。下面我們通過一個示例來了解下:
public Startup(IConfiguration configuration) { Configuration = configuration; var sectionExists0 = Configuration.GetSection("section2").Exists();//true var sectionExists1 = Configuration.GetSection("section2:subsection2").Exists();//false }
而通過啟動應用程序時會了解到section2配置節點如果存在就會返回true,反之則false;同理section2:subsection2路徑配置節點亦一樣。
3.3 XML配置
XmlConfigurationProvider在運行時會從XML文件鍵值對加載配置。若要激活XML文件配置,請在ConfigurationBuilder的實例上調用AddXmlFile擴展方法。現在我們在CoreWeb根目錄下添加一個XML配置文件(命名為config):
value value value value
而應用程序在構建主機時調用ConfigureAppConfiguration以指定應用程序的配置(這里我們指定config.xml文件):
public class Program { public static void Main(string[] args) { CreateWebHostBuilder(args).Build().Run(); } public static IWebHostBuilder CreateWebHostBuilder(string[] args) => WebHost.CreateDefaultBuilder(args) .ConfigureAppConfiguration((hostingContext, config) => { config.SetBasePath(Directory.GetCurrentDirectory()); config.AddXmlFile( "config.xml", optional: true, reloadOnChange: true); }) .UseStartup(); }
而通過啟動應用程序時會看到如下配置信息:
原文鏈接:https://www.cnblogs.com/wzk153/p/11263857.html
相關推薦
- 2022-06-21 .net中常用的正則表達式_C#教程
- 2022-10-09 .NET使用Moq進行單元測試_實用技巧
- 2022-11-05 利用Go語言實現輕量級OpenLdap弱密碼檢測工具_Golang
- 2022-09-06 C#面向對象編程中接口隔離原則的示例詳解_C#教程
- 2022-07-18 Linux文件系統和日志分析
- 2022-04-28 C#中Razor模板引擎簡單使用_C#教程
- 2022-06-28 C++詳解多線程中的線程同步與互斥量_C 語言
- 2023-11-20 python設置matplotlib.plot的坐標刻度和坐標范圍
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支