狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

.NET配置文件大揭秘:輕松讀取JSON、XML、INI和環(huán)境變量

freeflydom
2024年2月24日 14:30 本文熱度 606

 

概述:.NET中的IConfiguration接口提供了一種多源讀取配置信息的靈活機(jī)制,包括JSON、XML、INI文件和環(huán)境變量。通過示例,清晰演示了從這些不同源中讀取配置的方法,使配置獲取變得方便且易于擴(kuò)展。這種方式適用于不同場(chǎng)景,如API密鑰、數(shù)據(jù)庫(kù)連接等,為應(yīng)用提供了高度可配置性。

在.NET中,IConfiguration接口提供了一種靈活的方式來(lái)管理和讀取應(yīng)用程序配置信息。這可以包括來(lái)自不同源的配置信息,如JSON、XML、INI文件以及環(huán)境變量。

讀取JSON文件:

JSON文件通常用于保存結(jié)構(gòu)化的配置信息,例如Web應(yīng)用的設(shè)置、API密鑰等。

JSON文件內(nèi)容如下:

{
  "AppSettings": {
    "ApiKey": "your_api_key",
    "LogLevel": "Info"
  },
  "DatabaseSettings": {
    "ConnectionString": "your_connection_string",
    "TimeoutSeconds": 30
  }}

實(shí)例描述:

using Microsoft.Extensions.Configuration;

using System;


public class JsonConfigReader

{

    public static IConfigurationRoot ReadJsonFile(string filePath)

    {

        try

        {

            // 創(chuàng)建ConfigurationBuilder

            var builder = new ConfigurationBuilder();


            // 添加Json文件作為配置源

            builder.AddJsonFile(filePath);


            // 構(gòu)建IConfigurationRoot

            IConfigurationRoot config = builder.Build();


            return config;

        }

        catch (Exception ex)

        {

            Console.WriteLine($"讀取JSON文件失敗: {ex.Message}");

            return null;

        }

    }

}

使用示例:

public class Program

{

    public static void Main()

    {

        // 指定JSON文件路徑

        string jsonFilePath = "appsettings.json";


        // 讀取JSON文件內(nèi)容

        IConfigurationRoot config = JsonConfigReader.ReadJsonFile(jsonFilePath);


        if (config != null)

        {

            // 獲取配置項(xiàng)

            string apiKey = config["AppSettings:ApiKey"];

            string connectionStr = config["DatabaseSettings:ConnectionString"];


            Console.WriteLine($"API Key: {apiKey}, Database Connection: {connectionStr}");

        }

    }

}

讀取XML文件:

XML文件常用于保存包含大量元數(shù)據(jù)的配置信息,例如Windows應(yīng)用程序配置。

XML文件內(nèi)容如下:

<configuration>
  <AppSettings>
    <ApiKey>your_api_key</ApiKey>
    <LogLevel>Info</LogLevel>
  </AppSettings>
  <DatabaseSettings>
    <ConnectionString>your_connection_string</ConnectionString>
    <TimeoutSeconds>30</TimeoutSeconds>
  </DatabaseSettings></configuration>

實(shí)例描述:

using Microsoft.Extensions.Configuration;

using System;


public class XmlConfigReader

{

    public static IConfigurationRoot ReadXmlFile(string filePath)

    {

        try

        {

            // 創(chuàng)建ConfigurationBuilder

            var builder = new ConfigurationBuilder();


            // 添加Xml文件作為配置源

            builder.AddXmlFile(filePath);


            // 構(gòu)建IConfigurationRoot

            IConfigurationRoot config = builder.Build();


            return config;

        }

        catch (Exception ex)

        {

            Console.WriteLine($"讀取XML文件失敗: {ex.Message}");

            return null;

        }

    }

}

使用示例:

public class Program

{

    public static void Main()

    {

        // 指定XML文件路徑

        string xmlFilePath = "appsettings.xml";


        // 讀取XML文件內(nèi)容

        IConfigurationRoot config = XmlConfigReader.ReadXmlFile(xmlFilePath);


        if (config != null)

        {

            // 獲取配置項(xiàng)

            string apiKey = config["AppSettings:ApiKey"];

            string connectionStr = config["DatabaseSettings:ConnectionString"];


            Console.WriteLine($"API Key: {apiKey}, Database Connection: {connectionStr}");

        }

    }

}

讀取INI文件:

INI文件是一種簡(jiǎn)單的配置文件格式,通常用于保存簡(jiǎn)單的鍵值對(duì)配置。

INI文件內(nèi)容如下:

[AppSettings]

ApiKey=your_api_key

LogLevel=Info


[DatabaseSettings]

ConnectionString=your_connection_string

TimeoutSeconds=30

實(shí)例描述:

using Microsoft.Extensions.Configuration;

using System;


public class IniConfigReader

{

    public static IConfigurationRoot ReadIniFile(string filePath)

    {

        try

        {

            // 創(chuàng)建ConfigurationBuilder

            var builder = new ConfigurationBuilder();


            // 添加Ini文件作為配置源

            builder.AddIniFile(filePath);


            // 構(gòu)建IConfigurationRoot

            IConfigurationRoot config = builder.Build();


            return config;

        }

        catch (Exception ex)

        {

            Console.WriteLine($"讀取INI文件失敗: {ex.Message}");

            return null;

        }

    }

}

使用示例:

public class Program

{

    public static void Main()

    {

        // 指定INI文件路徑

        string iniFilePath = "appsettings.ini";


        // 讀取INI文件內(nèi)容

        IConfigurationRoot config = IniConfigReader.ReadIniFile(iniFilePath);


        if (config != null)

        {

            // 獲取配置項(xiàng)

            string apiKey = config["AppSettings:ApiKey"];

            string connectionStr =


 config["DatabaseSettings:ConnectionString"];


            Console.WriteLine($"API Key: {apiKey}, Database Connection: {connectionStr}");

        }

    }

}


讀取環(huán)境變量:

環(huán)境變量通常用于存儲(chǔ)敏感信息,如API密鑰或數(shù)據(jù)庫(kù)連接字符串。

實(shí)例描述:

using Microsoft.Extensions.Configuration;

using System;


public class EnvConfigReader

{

    public static IConfigurationRoot ReadEnvironmentVariables()

    {

        try

        {

            // 創(chuàng)建ConfigurationBuilder

            var builder = new ConfigurationBuilder();


            // 添加環(huán)境變量作為配置源

            builder.AddEnvironmentVariables();


            // 構(gòu)建IConfigurationRoot

            IConfigurationRoot config = builder.Build();


            return config;

        }

        catch (Exception ex)

        {

            Console.WriteLine($"讀取環(huán)境變量失敗: {ex.Message}");

            return null;

        }

    }

}

使用示例:

public class Program

{

    public static void Main()

    {

        // 讀取環(huán)境變量?jī)?nèi)容

        IConfigurationRoot config = EnvConfigReader.ReadEnvironmentVariables();


        if (config != null)

        {

            // 獲取配置項(xiàng)

            string apiKey = config["AppSettings:ApiKey"];

            string connectionStr = config["DatabaseSettings:ConnectionString"];


            Console.WriteLine($"API Key: {apiKey}, Database Connection: {connectionStr}");

        }

    }

}

以上代碼提供了使用IConfiguration讀取JSON、XML、INI文件以及環(huán)境變量的通用方法,使得配置信息的獲取更加靈活和便捷。

轉(zhuǎn)自https://www.cnblogs.com/hanbing81868164/p/18022302


該文章在 2024/2/24 14:30:14 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved