<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

        .NetCore獲取Json和Xml格式的配置信息

        來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:35:24
        文檔

        .NetCore獲取Json和Xml格式的配置信息

        .NetCore獲取Json和Xml格式的配置信息:本篇將和大家分享的是:如何獲取Json和Xml格式的配置信息,主要介紹的是Configuration擴(kuò)展方法的使用,因?yàn)閚etcore的web應(yīng)用在Startup中已經(jīng)默認(rèn)嵌入appsettings.json文件的配置信息,故而我把測(cè)試點(diǎn)放在在了netcore的控制臺(tái)應(yīng)用上;控制臺(tái)上使用配置
        推薦度:
        導(dǎo)讀.NetCore獲取Json和Xml格式的配置信息:本篇將和大家分享的是:如何獲取Json和Xml格式的配置信息,主要介紹的是Configuration擴(kuò)展方法的使用,因?yàn)閚etcore的web應(yīng)用在Startup中已經(jīng)默認(rèn)嵌入appsettings.json文件的配置信息,故而我把測(cè)試點(diǎn)放在在了netcore的控制臺(tái)應(yīng)用上;控制臺(tái)上使用配置

        本篇將和大家分享的是:如何獲取Json和Xml格式的配置信息,主要介紹的是Configuration擴(kuò)展方法的使用,因?yàn)閚etcore的web應(yīng)用在Startup中已經(jīng)默認(rèn)嵌入appsettings.json文件的配置信息,故而我把測(cè)試點(diǎn)放在在了netcore的控制臺(tái)應(yīng)用上;控制臺(tái)上使用配置文件也是常用的事情,并且官網(wǎng)實(shí)例主要講解的是json格式,對(duì)xml格式直接帶過了,因此有了本篇的分享,希望能給你好的幫助;

        1. 獲取Json配置信息
        2. 獲取Xml配置信息
        3. 獲取xml節(jié)點(diǎn)屬性值

        配置文件能否不和應(yīng)用放在一起呢? 答案是肯定的

        對(duì)于netcore的netstandard擴(kuò)展來(lái)說(shuō)其自帶了配置文件信息操作類,因?yàn)閏ore的Web應(yīng)用和控制臺(tái)應(yīng)用都是統(tǒng)一的,因此下面講解測(cè)試用例在控制臺(tái)應(yīng)用演示的,但是也可用于Web應(yīng)用;

        首先,咋們需要在控制臺(tái)應(yīng)用中引用如下nuget包(我這里測(cè)試基于2.0):

         Install-Package Microsoft.Extensions.Configuration -Version 2.0.0 
         Install-Package Microsoft.Extensions.Configuration.Abstractions -Version 2.0.0 

        獲取Json配置信息

        要獲取json配置我們除了上面兩個(gè)引用外,還需要引用:

         Install-Package Microsoft.Extensions.Configuration.Json -Version 2.0.0 

        這是json配置的基礎(chǔ)引用,我們?cè)诳刂婆_(tái)應(yīng)用中創(chuàng)建appsettings.json文件,并定義如下json配置文件信息:

        {
         "MyConfig": {
         "UserName": "神牛步行3",
         "userPwd": "666666",
         "GaoDeApi": {
         "UserName": "神牛步行1",
         "userPwd": "111111"
         },
         "BaiDuApi":{
         "userName": "神牛步行2",
         "userPwd": "222222"
         }
         }
        }

        然后只需要如下代碼,即可獲取到該文件信息:

        var configBasePath = Directory.GetCurrentDirectory(); //configBasePath = @"D:\D\TTest";
        sbLog.Append($"配置文件所在目錄:{configBasePath}\n");
        var builder = new ConfigurationBuilder().
         SetBasePath(configBasePath).
         AddJsonFile("appsettings.json");
        var config = builder.Build();
        sbLog.Append($"MyConfig:UserName節(jié)點(diǎn)的值:{config.GetSection("MyConfig:UserName").Value}");

        對(duì)于已經(jīng)有core開發(fā)經(jīng)驗(yàn)的朋友而言,上面直接能看懂,不過為了完善的講解這里還是需要簡(jiǎn)單說(shuō)下的:

        ConfigurationBuilder實(shí)例過后需要通過SetBasePath方法設(shè)置配置文件基礎(chǔ)路徑,再通過AddJsonFile擴(kuò)展方法指定讀取的文件名稱;這些步驟執(zhí)行返回的都是IConfigurationBuilder接口,最后還需要Build方法執(zhí)行加載配置信息,這個(gè)builder有點(diǎn)類似于start的意思;來(lái)看看效果圖:

        很顯然這里獲取到了配置文件中的MyConfig:UserName節(jié)點(diǎn)的值,這里通過 IConfigurationSection GetSection(string key); 函數(shù)獲取配置節(jié)點(diǎn),配置節(jié)點(diǎn)層級(jí)關(guān)系通過“:”鏈接,因此這里就有了key=MyConfig:UserName;

        為了程序的美觀性和多使用性,這里吧獲取json文件的封裝為如下方法:

        /// <summary>
        /// json配置文件讀取
        /// </summary>
        /// <param name="configFileName"></param>
        /// <param name="basePath"></param>
        /// <returns></returns>
        public static IConfigurationRoot GetJsonConfig(
         string configFileName = "appsettings.json",
         string basePath = "")
        {
         basePath = string.IsNullOrWhiteSpace(basePath) ? Directory.GetCurrentDirectory() : basePath;
         var builder = new ConfigurationBuilder().
         SetBasePath(basePath).
         AddJsonFile(configFileName);
         return builder.Build();
        }

        對(duì)了這里注意下AddJsonFile方法是通過開節(jié)引用的 Microsoft.Extensions.Configuration.Json 擴(kuò)展的;由于IConfiguration不光用GetSection函數(shù),她也能根據(jù) this[string key] 方式獲取節(jié)點(diǎn),下面是分別獲取高德地圖和百度地圖配置節(jié)點(diǎn)信息的代碼和效果圖:

        var configJson = GetJsonConfig();
        sbLog.Append($"json配置-MyConfg節(jié)點(diǎn)的值:\n");
        sbLog.Append($"高德-UserName:{configJson.GetSection("MyConfig:GaoDeApi:UserName").Value}\n");
        sbLog.Append($"百度-userName:{configJson["MyConfig:BaiDuApi:UserName"]}\n\r\n");

        注意:節(jié)點(diǎn)不區(qū)分大小寫,多級(jí)節(jié)點(diǎn)使用‘:'獲取;

        獲取Xml配置信息

        xml配置文件也是我們常見的,對(duì)已擴(kuò)展的IConfigurationBuilder來(lái)說(shuō),我們同樣也有類似于json那樣擴(kuò)展的方法,首先需要引用如下包:

         Install-Package Microsoft.Extensions.Configuration.Xml -Version 2.0.0 

        然后幾乎和json同樣的代碼獲取xml配置文件:

        /// <summary>
        /// xml配置文件讀取
        /// </summary>
        /// <param name="configFileName"></param>
        /// <param name="basePath"></param>
        /// <returns></returns>
        public static IConfigurationRoot GetXmlConfig(
         string configFileName = "appsettings.xml",
         string basePath = "")
        {
         basePath = string.IsNullOrWhiteSpace(basePath) ? Directory.GetCurrentDirectory() : basePath;
         var builder = new ConfigurationBuilder().
         //SetBasePath(basePath).
         AddXmlFile(b =>
         {
         b.Path = configFileName;
         b.FileProvider = new PhysicalFileProvider(basePath);
         });
         return builder.Build();
        }

        區(qū)別在于擴(kuò)展IConfigurationBuilder的AddXmlFile方法,本次示例為了多樣化使用了 public static IConfigurationBuilder AddXmlFile(this IConfigurationBuilder builder, Action<XmlConfigurationSource> configureSource) 來(lái)傳遞配置文件名稱和基礎(chǔ)路徑;

        下面來(lái)新建并初始化appsettings.xml配置文件信息:

        <MyConfig>
         <GaoDeApi>
         <UserName des="高德的賬號(hào)">神牛步行1</UserName>
         <userPwd>111111</userPwd>
         </GaoDeApi>
         <BaiDuApi>
         <userName des="百度的賬號(hào)">神牛步行2</userName>
         <userPwd>222222</userPwd>
         </BaiDuApi>
        </MyConfig>

        再來(lái)看看調(diào)用獲取配置節(jié)點(diǎn)的部分代碼:

        var configXml = GetXmlConfig();
        sbLog.Append($"xml配置-MyConfg節(jié)點(diǎn)的值:\n");
        sbLog.Append($"高德-UserName:{configXml.GetSection("GaoDeApi:UserName").Value}\n");
        sbLog.Append($"百度-userName:{configXml["BaiDuApi:UserName"]}\n\r\n");

        能夠看出xml和json讀取配置節(jié)點(diǎn)的方式一樣“:”表示層級(jí)關(guān)系,但是特別注意點(diǎn)在于xml不需要最外層跟節(jié)點(diǎn),如這里的:GaoDeApi:UserName,如果按照json方式的話這里的key應(yīng)該是這樣:MyConfig:GaoDeApi:UserName,這里就是兩種的另外一種區(qū)別;如圖:

        不出以外json和xml配置信息都能獲取到了;

        獲取xml節(jié)點(diǎn)屬性值

        通常xml配置文件節(jié)點(diǎn)還有屬性(attribute),如上面的xml節(jié)點(diǎn): <UserName des="高德的賬號(hào)">神牛步行1</UserName> ,這個(gè)des=""就是屬性,我們要怎么才能獲取這個(gè)值呢;這里其實(shí)同樣還是通過':'來(lái)關(guān)聯(lián)的,如下代碼獲取屬性節(jié)點(diǎn)des的值:

        sbLog.Append($"高德-UserName-des:{configXml.GetSection("GaoDeApi:UserName:des").Value}\n");
        sbLog.Append($"百度-userName-des:{configXml["BaiDuApi:UserName:des"]}\n\r\n");

        xml屬性節(jié)點(diǎn)名稱不能是name,不然是無(wú)法讀取成功的;如這里的des改成name名稱的話,無(wú)法正常獲取信息,謹(jǐn)記于心;

        配置文件能否不和應(yīng)用放在一起呢? 答案是肯定的

        有部分朋友會(huì)提出一個(gè)問題:配置文件能否不和應(yīng)用放在一起呢? 答案是肯定的,我們只需把Directory.GetCurrentDirectory()(獲取當(dāng)前應(yīng)用所在磁盤目錄)替換成配置文件所在的基礎(chǔ)目錄就行了,如我這里的: configBasePath = @"D:\D\TTest";

        下面是本次實(shí)例的整個(gè)測(cè)試用例代碼:

        using Microsoft.Extensions.Configuration;
        using Microsoft.Extensions.Configuration.Json;
        using Microsoft.Extensions.FileProviders;
        using System;
        using System.Diagnostics;
        using System.IO;
        using System.Text;
        namespace MyService
        {
         class Program
         {
         static void Main(string[] args)
         {
         Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
         Console.OutputEncoding = Encoding.GetEncoding("GB2312");
         var sbLog = new StringBuilder(string.Empty);
         var configBasePath = Directory.GetCurrentDirectory(); //configBasePath = @"D:\D\TTest";
         sbLog.Append($"配置文件所在目錄:{configBasePath}\n");
         var builder = new ConfigurationBuilder().
         SetBasePath(configBasePath).
         AddJsonFile("appsettings.json");
         var config = builder.Build();
         sbLog.Append($"MyConfig:UserName節(jié)點(diǎn)的值:{config.GetSection("MyConfig:UserName").Value}\n\r\n");
         var configJson = GetJsonConfig();
         sbLog.Append($"json配置-MyConfg節(jié)點(diǎn)的值:\n");
         sbLog.Append($"高德-UserName:{configJson.GetSection("MyConfig:GaoDeApi:UserName").Value}\n");
         sbLog.Append($"百度-userName:{configJson["MyConfig:BaiDuApi:UserName"]}\n\r\n");
         var configXml = GetXmlConfig();
         sbLog.Append($"xml配置-MyConfg節(jié)點(diǎn)的值:\n");
         sbLog.Append($"高德-UserName:{configXml.GetSection("GaoDeApi:UserName").Value}\n");
         sbLog.Append($"百度-userName:{configXml["BaiDuApi:UserName"]}\n\r\n");
         sbLog.Append($"高德-UserName-des:{configXml.GetSection("GaoDeApi:UserName:des").Value}\n");
         sbLog.Append($"百度-userName-des:{configXml["BaiDuApi:UserName:des"]}\n\r\n");
         Console.WriteLine(sbLog);
         Console.ReadLine();
         }
         /// <summary>
         /// json配置文件讀取
         /// </summary>
         /// <param name="configFileName"></param>
         /// <param name="basePath"></param>
         /// <returns></returns>
         public static IConfigurationRoot GetJsonConfig(
         string configFileName = "appsettings.json",
         string basePath = "")
         {
         basePath = string.IsNullOrWhiteSpace(basePath) ? Directory.GetCurrentDirectory() : basePath;
         var builder = new ConfigurationBuilder().
         SetBasePath(basePath).
         AddJsonFile(configFileName);
         return builder.Build();
         }
         /// <summary>
         /// xml配置文件讀取
         /// </summary>
         /// <param name="configFileName"></param>
         /// <param name="basePath"></param>
         /// <returns></returns>
         public static IConfigurationRoot GetXmlConfig(
         string configFileName = "appsettings.xml",
         string basePath = "")
         {
         basePath = string.IsNullOrWhiteSpace(basePath) ? Directory.GetCurrentDirectory() : basePath;
         var builder = new ConfigurationBuilder().
         //SetBasePath(basePath).
         AddXmlFile(b =>
         {
         b.Path = configFileName;
         b.FileProvider = new PhysicalFileProvider(basePath);
         });
         return builder.Build();
         }
         }
        }

        總結(jié)

        以上所述是小編給大家介紹的.NetCore獲取Json和Xml格式的配置信息,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

        聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        .NetCore獲取Json和Xml格式的配置信息

        .NetCore獲取Json和Xml格式的配置信息:本篇將和大家分享的是:如何獲取Json和Xml格式的配置信息,主要介紹的是Configuration擴(kuò)展方法的使用,因?yàn)閚etcore的web應(yīng)用在Startup中已經(jīng)默認(rèn)嵌入appsettings.json文件的配置信息,故而我把測(cè)試點(diǎn)放在在了netcore的控制臺(tái)應(yīng)用上;控制臺(tái)上使用配置
        推薦度:
        標(biāo)簽: 配置 讀取 xml
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲精品mv在线观看| 亚洲国产精品综合久久一线| 亚洲欧洲日产国码无码久久99 | 亚洲色偷偷色噜噜狠狠99| 最近新韩国日本免费观看| 亚洲手机中文字幕| 成人免费黄色网址| 亚洲中文字幕精品久久| 最新猫咪www免费人成| 亚洲精品第一国产综合亚AV| 日本免费网站观看| 免费一区二区无码视频在线播放| 亚洲国产一成久久精品国产成人综合| yellow视频免费在线观看| 77777亚洲午夜久久多人| 97无码人妻福利免费公开在线视频 | 亚洲国产综合精品中文第一| 成年性生交大片免费看| 亚洲av无码成人精品国产| 亚洲国产a级视频| 中文字幕在线免费看线人| 亚洲人成网站影音先锋播放| 日韩在线免费视频| 亚洲精品乱码久久久久久V | AV免费网址在线观看| 亚洲av无码日韩av无码网站冲| 亚洲国产成人久久综合碰| 花蝴蝶免费视频在线观看高清版| 久久久久亚洲av无码专区导航| 九九九精品成人免费视频| 美女羞羞免费视频网站| 亚洲成av人片天堂网| aⅴ在线免费观看| 国产成人不卡亚洲精品91| 亚洲阿v天堂在线| 扒开双腿猛进入爽爽免费视频| av午夜福利一片免费看久久| 亚洲精品国产啊女成拍色拍| 亚洲国产成人VA在线观看| 久久99热精品免费观看动漫| 亚洲成av人片天堂网无码】|