溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

ASP.NET?Core中的Configuration怎么配置

發(fā)布時間:2022-04-07 11:07:15 來源:億速云 閱讀:171 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“ASP.NET Core中的Configuration怎么配置”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“ASP.NET Core中的Configuration怎么配置”吧!

1.前言

ASP.NET Core在應(yīng)用程序上引入Microsoft.Extensions.Configuration配置,可以支持多種方式配置,包括命令行配置、環(huán)境變量配置、文件配置、內(nèi)存配置,自定義配置等等。下面我們就其中幾個配置來聊聊。

2.命令行配置

CommandLineConfigurationProvider在應(yīng)用程序運行時會從(例如DOS)命令行參數(shù)鍵值加載配置。要激活命令行配置,請在ConfigurationBuilder的實例上調(diào)用AddCommandLine擴(kuò)展方法。使用CreateDefaultBuilder初始化新的WebHostBuilder時會自動調(diào)用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視圖上添加如下代碼后發(fā)布一個Web版本掛載在IIS上。

ASP.NET?Core中的Configuration怎么配置

ASP.NET?Core中的Configuration怎么配置

在控制臺上輸入DOS命令行dotnet D:\Release\Core\TestWebApp.dll CommandLineKey1=value1配置鍵:CommandLineKey1,值:value1的信息,會看到如下界面信息:

ASP.NET?Core中的Configuration怎么配置

根據(jù)控制臺監(jiān)聽站點連接,在瀏覽器上打開其中一個,比如打開https://localhost:5001/,會看到我們配置命令行信息:

ASP.NET?Core中的Configuration怎么配置

3.文件配置

FileConfigurationProvider是從文件系統(tǒng)加載配置的基類。以下配置為應(yīng)用程序提供專用于特定文件類型:INI配置、JSON配置、XML配置。

3.1 INI配置

IniConfigurationProvider在運行時會從INI文件鍵值對加載配置。若要激活I(lǐng)NI文件配置,請在 ConfigurationBuilder的實例上調(diào)用AddIniFile擴(kuò)展方法,而冒號可用作INI文件配置中的節(jié)點分隔符?,F(xiàn)在我們在CoreWeb根目錄下添加一個INI配置文件(命名為config):

[section0]
key0=value
key1=value
[section1]
subsection:key=value
[section2:subsection0]
key=value
[section2:subsection1]
key=value

而應(yīng)用程序在構(gòu)建主機(jī)時會調(diào)用ConfigureAppConfiguration以指定應(yīng)用程序配置(這里我們指定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設(shè)置了文件訪問初始路徑。Optional:文件是否可選;reloadOnChange:如果文件更改,是否應(yīng)重新加載配置。而通過啟動應(yīng)用程序時會看到如下配置信息:

ASP.NET?Core中的Configuration怎么配置

3.2 JSON配置

JsonConfigurationProvider在運行時期間會從JSON文件鍵值對加載配置。若要激活JSON文件配置,請在ConfigurationBuilder的實例上調(diào)用AddJsonFile擴(kuò)展方法。使用 CreateDefaultBuilder初始化新的WebHostBuilder時,會自動調(diào)用AddJsonFile兩次,調(diào)用該方法(AddJsonFile)來從以下文件加載配置,首先會讀取appsettings.json該文件。而應(yīng)用程序啟動時是會默認(rèn)調(diào)用對應(yīng)的appsettings.{Environment}.json環(huán)境版本的,例如appsettings.{Environment}.json會根據(jù)IHostingEnvironment.EnvironmentName加載對應(yīng)文件的環(huán)境版本(開發(fā)模式、生產(chǎn)模式等)?,F(xiàn)在我們在CoreWeb根目錄下添加一個JSON配置文件(命名為config):

{
  "section0": {
    "key0": "key0value",
    "key1": "key1value"
  },
  "section1": {
    "key0": "key0value",
    "key1": "key1value"
  },
  "section2": {
    "subsection0": {
      "key0": "sub0key0value",
      "key1": "sub0key1value"
    },
    "subsection1": {
      "key0": "sub1key0value",
      "key1": "sub1key1value"
    }
  }
}

而應(yīng)用程序在構(gòu)建主機(jī)時會調(diào)用ConfigureAppConfiguration以指定除appsettings.json和appsettings.{Environment}.json以外文件的應(yīng)用程序配置(這里我們指定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>();
}

而通過啟動應(yīng)用程序時會看到如下配置信息:

ASP.NET?Core中的Configuration怎么配置

從上述信息可以看到,在我們指定config.json文件后,IConfigurationBuilder會額外多調(diào)用一次AddJsonFile,加上前兩次AddJsonFile,一共是三次。

3.2.1GetSection、GetChildren和Exists

(1)GetSection:IConfiguration.GetSection獲取指定配置子節(jié)。下面我們通過一個示例來了解下:

public Startup(IConfiguration configuration)
{
    Configuration = configuration;
    var configSection0 = Configuration.GetSection("section0");
    var configSection1 = Configuration.GetSection("section0:key0");
}

而通過啟動應(yīng)用程序時會看到如下配置信息:

ASP.NET?Core中的Configuration怎么配置

ASP.NET?Core中的Configuration怎么配置

通過上述示例可以看到,IConfiguration.GetSection僅僅是獲取到j(luò)son數(shù)據(jù)里面configSection0節(jié)點鍵和路徑,并沒有獲取到它的節(jié)點值。若要獲取section0:key0中的鍵值,請在調(diào)用GetSection時提供完整節(jié)點路徑,如獲取configSection1鍵值示例。
(2)GetChildren:獲取指定配置樹節(jié)點。下面我們通過一個示例來了解下:

public Startup(IConfiguration configuration)
{
    Configuration = configuration;
    var configSection = Configuration.GetSection("section2");
    var children = configSection.GetChildren();
}

而通過啟動應(yīng)用程序時會看到如下配置信息:

ASP.NET?Core中的Configuration怎么配置

ASP.NET?Core中的Configuration怎么配置

GetChildren獲取了指定section2節(jié)點下所有節(jié)點。
(3)Exists:使用ConfigurationExtensions.Exists確定配置節(jié)點是否存在。下面我們通過一個示例來了解下:

public Startup(IConfiguration configuration)
{
    Configuration = configuration;
    var sectionExists0 = Configuration.GetSection("section2").Exists();//true
    var sectionExists1 = Configuration.GetSection("section2:subsection2").Exists();//false
}

而通過啟動應(yīng)用程序時會了解到section2配置節(jié)點如果存在就會返回true,反之則false;同理section2:subsection2路徑配置節(jié)點亦一樣。

3.3 XML配置

XmlConfigurationProvider在運行時會從XML文件鍵值對加載配置。若要激活XML文件配置,請在ConfigurationBuilder的實例上調(diào)用AddXmlFile擴(kuò)展方法?,F(xiàn)在我們在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>

而應(yīng)用程序在構(gòu)建主機(jī)時調(diào)用ConfigureAppConfiguration以指定應(yīng)用程序的配置(這里我們指定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>();
}

而通過啟動應(yīng)用程序時會看到如下配置信息:

ASP.NET?Core中的Configuration怎么配置

感謝各位的閱讀,以上就是“ASP.NET Core中的Configuration怎么配置”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對ASP.NET Core中的Configuration怎么配置這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI