(11)ASP.NET Core 中的配置一(Configuration)

来源:https://www.cnblogs.com/wzk153/archive/2019/07/29/11263857.html
-Advertisement-
Play Games

1.前言 ASP.NET Core在應用程式上引入Microsoft.Extensions.Configuration配置,可以支持多種方式配置,包括命令行配置、環境變數配置、文件配置、記憶體配置,自定義配置等等。下麵我們就其中幾個配置來聊聊。 2.命令行配置 CommandLineConfigura ...


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<Startup>();
}

在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<Startup>();
}

從上述代碼可以看到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<Startup>();
}

而通過啟動應用程式時會看到如下配置信息:

從上述信息可以看到,在我們指定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):

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <section0>
    <key0>value</key0>
    <key1>value</key1>
  </section0>
  <section1>
    <key0>value</key0>
    <key1>value</key1>
  </section1>
</configuration>

而應用程式在構建主機時調用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<Startup>();
}

而通過啟動應用程式時會看到如下配置信息:

 

參考文獻:
ASP.NET Core 中的配置


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、.NET Remoting概念 1、一種分散式處理方式。從字面意義上看出,他是基於.net平臺的一種遠程對象開發技術,該技術是將遠程電腦中的數據視為分散式對象來進行開發。 2、一種網路通信技術。既然這種技術可以操作遠程電腦的數據,他當然是網路通信技術。 2、.NET Remoting使用的技 ...
  • 先看看列印入庫單的效果圖,看如下: 客戶要求合計一行,要求大寫中文數字。XtraReport報表是如何做出以上圖的效果呢?因為是要把數字轉成大寫中文數字,得先準備數字轉大寫中文數字的函數。因網上有很多方法,我這裡就不上傳代碼了。這裡只說一下XtraReport報表創建以上收貨單報表大寫數字操作。新建 ...
  • .NET Core CSharp 中級篇 2 1 本節內容為裝箱與拆箱 簡介 裝箱和拆箱是一個相對抽象的概念。你可以想象一下一堆滿載貨物的大卡車,他是由許多工人將貨物集中堆放裝入的,對於我們而言在沒有打開貨箱的時候,我們可以知道這是一輛運貨的卡車,裡面有著許多貨物,但是具體貨物是什麼,我們只有打開後 ...
  • 這幾天本人接了個檔案管理查詢系統的小項目,踩過的坑。 其實功能都挺簡單的,大致要求客戶有很多pdf文檔,為了方便管理,所有要開發一個相當於文件管理系統,本人正好有現成的文件管理系統,修改下就可以。其中客戶要求pdf需要放到其他的盤符,不能和應用程式在一起,這個解決起來非常方便。系統上線了後,因為客戶 ...
  • 這些區域性通常分為三個集合:固定區域性、非特定區域性和特定區域性。 固定區域性不區分區域性。可以使用空字元串 ("") 按名稱或者按區域性標識符 0x007F 來指定固定區域性。它與英語語言關聯,但不與任何國家/地區關聯。它幾乎可用在要求區域性的“全局化”命名空間中的所有方法中。 非特定區域性是與某 ...
  • demo地址: "ABP.WindowsService" 該文章是系列文章 "基於.NetCore和ABP框架如何讓Windows服務執行Quartz定時作業" 的其中一篇。 參考:https://aspnetboilerplate.com/Pages/Documents/Logging ABP框架 ...
  • 前言:何謂版本控制系統吶?有兩種說法:一種叫法為SCM,==source code management (源代碼管理系統)另一種說法為VCS,==version control system (版本控制系統),既然兩種叫法都可以的話,姑且把她叫成版本控制系統吧,從名稱不難看出此系統一是用來解決代碼 ...
  • 前言 在記憶體當道的日子里,無論什麼時候都要考慮這些代碼是否會影響程式性能呢? 在現在的世界里,幾乎不會去考慮用了幾百毫秒,可是在特別的場景了,往往這幾百毫米確影響了整個項目的快慢。 通過瞭解這兩者之間的性能差異,希望幫助大家在合適的場景里選擇正確的編碼。 實例 c public class Poin ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...