跟我一起学.NetCore之配置初体验

前言

    配置对于程序来说,绝对是必不可少,毕竟配置是应用或组件动态适应各种环境的最优方案,没有之一(我还年轻,我是这么认为的);之前可能用的最多的配置源是命令行、文件(XML、Json、INI),Web中对于Asp.Net程序员Web.Config是接触的再多不过了,不管怎样,读取配置信息是避免不了啦,但是对于各种配置源不同及格式不同,又得专门开发对应的配置解析程序;不慌,.NetCore内置的配置框架为此一解烦恼,开箱即用,正文详解,走起~~~

正文

    体验之前,简单聊聊有关配置的几个核心类型及其对应的联系;

  • IConfiguration:暴露给我们使用的配置对象,其实是底层将不同数据结构的原始数据提取,并进行封装成一个具有树形化层次结构的IConfiguration对象;根节点和其他配置节点都继承IConfiguration;

    namespace Microsoft.Extensions.Configuration
    {public interface IConfiguration{// 索引访问    string this[string key] { get; set; }// 指定Key获取 配置节点        IConfigurationSection GetSection(string key);// 配置子节点          IEnumerable<IConfigurationSection> GetChildren();// 用于配置变化通知使用        IChangeToken GetReloadToken();}
    }

          IConfigurationRoot:根节点,配置的根;

namespace Microsoft.Extensions.Configuration
{public interface IConfigurationRoot : IConfiguration{// 对配置数据的重新加载,因为是根,所以会重新加载全部数据void Reload();// 用于不同配置源获取获取数据IEnumerable<IConfigurationProvider> Providers { get; }}
}

   IConfigurationSection:其他配置节点,可以理解为子节点;

namespace Microsoft.Extensions.Configuration
{public interface IConfigurationSection : IConfiguration{// 数据指定Key值string Key { get; }// 逻辑树的路径,层次用冒号:隔开,如SectionA:SectionBstring Path { get; }// 承载的配置数据string Value { get; set; }}
}

关系图如下:

  • IConfigurationProvider:真正读取原始配置的数据,并将其转换成一个中间字典的结构,最后再封装成IConfiguration;

    namespace Microsoft.Extensions.Configuration
    {public interface IConfigurationProvider{   // 获取指定Key的值bool TryGet(string key, out string value);// 设置对应Key值void Set(string key, string value);IChangeToken GetReloadToken();// 加载配置数据void Load();// 获取指定配置节点所有子节点KeyIEnumerable<string> GetChildKeys(IEnumerable<string> earlierKeys, string parentPath);}
    }
    
  • IConfigurationSource:原始配置源的体现,每种配置源都会有一个实现该接口的实现类,由于真正读取配置数据是委托IConfigurationProvider对象进行读取的,所以IConfigurationSource的作用就是为了提供IConfigurationProvider对象;

    namespace Microsoft.Extensions.Configuration
    {public interface IConfigurationSource{// 提供对应的 IConfigurationProvider对象IConfigurationProvider Build(IConfigurationBuilder builder);}
    }
    
  • IConfigurationBuilder:将IConfigurationSource配置源注册进行,通过调用其Build方法构造出IConfiguration;

    namespace Microsoft.Extensions.Configuration
    {public interface IConfigurationBuilder{IDictionary<string, object> Properties { get; }// 保存所有注册进来的 配置源        IList<IConfigurationSource> Sources { get; }// 注册配置源        IConfigurationBuilder Add(IConfigurationSource source);// 构造出一个Root对象,然后通过root对象就能获取p,并获取对应上面的值        IConfigurationRoot Build();}
    }
    

   核心对象关系总结:

  1. IConfigurationProvider真正读取配置数据,并将其封装为中间字典;

  2. 同的配置源IConfigurationSource提供对应的IConfigurationProvider对象;

  3. 通过IConfigurationBuilder将不同的IConfigurationSource配置源进行注册,并创建出对应的IConfiguration对象;

  4. 通过创建的IConfiguration对象就可以获取指定节点的值;

    核心类型及其关系就简单说这么多,接下来对不同配置源进行使用体验一把,接下来用一个控制台程序进行演示,老规矩,先通过Nuget安装核心包:

    开始撸代码:

  • 内存配置源

     运行结果:

  • 命令行配置源

    命令行支持的格式:

    A. 无前缀的 key=value模式

    B. 双中横线模式 --key=value或 --key value

    C. 正斜杠模式 /key=value或 /key value

    开撸:

    增加命令行扩展包:

    模拟命令行传参,两种方式:

    项目属性里面配置

        直接在launchSettings.json中配置

       代码   

        运行结果

  • 文件配置源

    通过Nuget安装对应文件类型的包,如下

    准备xml、json、ini三个配置源不同的文件

    代码应用

    运行,正常获取值

  • 环境变量配置源

       在之前,估计想不到合适的应用场景将环境变量作为配置源,对不对,如果有,那应该不多;但是现如今docker的存在,让其变得常用,因为毕竟容器的隔离使得环境变量可以针对对应的容器进行配置;

    通过Nuget安装包

    

    模拟环境变量配置

    代码走起

    运行结果

   

总结

    这里先写到这吧,太晚了(明天整理一下发出),这里大概说了几个关键类型的作用及关系,然后针对不同配置源进行举例演示,用法基本上都是这样,是不是很简单;下次咱们聊聊热更新;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/307713.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ 学习之旅(6)——循环loop

C中最为常用的三种循环&#xff1a;for 循环、while 循环和 do-while 循环&#xff0c;直接上代码&#xff1a; for循环 for ( init; condition; increment ) {statement(s); }init 会首先被执行&#xff0c;且只会执行一次。这一步允许您声明并初始化任何循环控制变量。您也…

JVM笔记(JVM内存+垃圾回收器)详解

一:java代码的执行流程(引出JVM) 首先由程序员编写成.java文件然后由javac(java编辑器)将.java文件编译成.class文件.class文件可以在不同平台/操作系统上的JVM上执行再由JVM编译成可供不同操作系统识别的机器码&#xff08;0,1二进制&#xff09; 二:JVM来源 我们在下载JD…

跟我一起学.NetCore之Asp.NetCore中集成Autofac扩展

前言前两节针对.NetCore自带的依赖注入进行简要概述&#xff0c;对于日常开发的需求应该是能满足了&#xff0c;那为什么还需要引入第三方依赖注入组件呢&#xff0c;这里就从自带的依赖注入来分析&#xff0c;有什么样的需求满足不了&#xff1f;主要归纳为以下几点&#xff1…

C++ 学习之旅(7)——指针pointer

开门见山&#xff0c;如果把计算机的内存空间比作是一排房子&#xff0c;那指针就是房门号。指针实际上就是一个用来存储内存地址的整数&#xff0c;与类型没有关系&#xff0c;我可以定义一个void类型的指针&#xff1a; #include <iostream>int main() {int var 8;v…

leetcode509. 斐波那契数

一:论语 我现在应该还没到壮年 还在年少 应该。。。。。。。。。。。。。。。 二:题目 三:上码 class Solution { public:/**思路:动态规划5步曲1.确定dp数组以及下标的含义dp[i] 的定义为:第i个斐波那契数的数值是dp[i]2.确定递推公式状态转移方程 dp[i] dp[i-1] dp[i-2…

C++ 学习之旅(8)——一文搞懂指针、引用、函数参数的传值调用、指针调用和引用调用

废话少说&#xff0c;直接上代码&#xff1a; #include <iostream>int main() {int a 5;int* ptr &a;int& ref a;std::cin.get(); //设置断点 }为了避免混淆&#xff0c;我建议在定义指针时写int* ptr而不是int *ptr&#xff0c;同理&#xff0c;定义引用写…

.NET Core 下使用 Kafka

安装CentOS 安装 kafkaKafka : http://kafka.apache.org/downloadsZooLeeper : https://zookeeper.apache.org/releases.html下载并解压# 下载&#xff0c;并解压 $ wget https://archive.apache.org/dist/kafka/2.1.1/kafka_2.12-2.1.1.tgz $ tar -zxvf kafka_2.12-2.1.1.tgz…

leetcode70. 爬楼梯

一:题目 二:上码 class Solution { public:/**思路&#xff1a;分析题意:爬到第一层楼有一种方法,爬到第二层楼有两种方法那么由第一层到第三层需要跨2步,由第二层到第三层需要跨一步;那么到第三层的方法可以由 到第一层和第二层推导出来(因为只剩下最后一步了)动态规划五步走…

C++ 学习之旅(9)——类Class与结构Struct

类的出现就是把同一类事物的变量和函数组织在一起&#xff0c;让我们可以更方便地对多个相关联的变量进行操作。类是C独有的&#xff0c;而结构则是从C拿过来的&#xff0c;它们之间只有三个区别&#xff1a; &#xff08;1&#xff09;class 中默认的成员访问权限是 private …

发现一款.NET Core开源爬虫神器:DotnetSpider

没有爬虫就没有互联网&#xff01;爬虫的意义在于采集大批量数据&#xff0c;然后基于此进行加工/分析&#xff0c;做更有意义的事情。谷歌&#xff0c;百度&#xff0c;今日头条&#xff0c;天眼查都离不开爬虫。去开源中国和Github查询C#的爬虫项目&#xff0c;仅有几个非常简…

leetcode746. 使用最小花费爬楼梯

一:题目 二:上码 class Solution { public:/**思路:1.分析题意给出的数组的下标代表楼梯的台阶数2.动态规划五步走1>:确定dp数组以及下标的含义dp[i]:表示到达第i层所需要花费的体力2>:确定dp数组的递推公式那么如何得到dp[i](花费的体力)呢&#xff1f;dp[i]由dp[i-1]或…

C++ 学习之旅(10)——static与extern

只要你看过我系列中之前关于编译和链接的内容&#xff0c;你就能看懂以下内容&#xff0c;直接上例子&#xff1a; Static.cpp int S_var 5;main.cpp #include <iostream>int S_var 10;int main() {std::cout << S_var << std::endl;std::cin.get(); }…

SS CMS 全新跨平台 V7.0 版本正式发布

今天&#xff0c;我们很高兴宣布基于.NET CORE平台的全新 SS CMS V7.0正式发布&#xff0c;新版本采用.NET CORE模块化和高性能实现&#xff0c;用于创建在Windows&#xff0c;Linux、Mac以及Docker上运行的Web应用程序和服务。SS CMS 7.0 之旅在此&#xff0c;我们简单回顾一下…

leetcode62. 不同路径

一:题目 二:上码 class Solution { public:/**思路:1.分析题意:2.动态规划五步走:1>:确定dp数组和其下标的含义dp[i][j]为到达二维数组下标为i&#xff0c;j的路径条数,i和j为下标2>:确定dp数组的递推公式那么dp[i][j]是如何求解出来的呢?只能是两个方向左边:dp[i-1][j…

C++ 学习之旅(11)——类和结构中的static

当我们使用 static 关键字来把类或者结构成员定义为静态的时侯&#xff0c;无论之后创建多少个类的对象&#xff08;实例&#xff09;&#xff0c;静态成员都只有一个副本&#xff0c;所有实例都共享这个副本。也就是说&#xff0c;静态成员已经不属于实例了&#xff0c;它归属…

推荐一本基于ASP.NET Core 3.1的实战来了

第一本基于 ASP.NET Core 3.1 的实战书来了我脱产花费了一年时间创作书籍《深入浅出 ASP.NET Core》&#xff0c;终于上架了。目前天猫、京东等主流平台均有销售。这本书是基于.NET Core3.1 平台&#xff0c;从 ASP.NET Core 的基础入门,通过项目实战结合 ASP.NET Core 源代码解…

C++ 学习之旅(12)——static用法小结

&#xff08;1&#xff09;在修饰变量的时候&#xff0c;static 修饰的静态局部变量只执行初始化一次&#xff0c;而且延长了局部变量的生命周期&#xff0c;直到程序运行结束以后才释放。 &#xff08;2&#xff09;static 修饰全局变量的时候&#xff0c;这个全局变量只能在…

leetcode63. 不同路径 II

一:题目 二&#xff1a;上码 class Solution { public:/**思路:1.分析题意:这里有障碍物,所以我们的做法会有点变化&#xff0c;如果这个障碍物出现在左侧或则右测的话那么我们确定的是其障碍物包括其后面的下标将均为0,如果障碍物出现在上诉区域外的话&#xff0c;那么就直接…

C#刷剑指Offer | 从上到下打印二叉树

【C#刷题】| 作者 / Edison Zhou这是EdisonTalk的第288篇原创内容我们来用之前学到的数据结构知识来刷《剑指Offer》的一些核心题目&#xff08;精选了其中30道题目&#xff09;&#xff0c;希望对你有帮助&#xff01;本文题目为&#xff1a;从上到下打印二叉树。1题目介绍题目…

C++ 学习之旅(13)——枚举enum

所谓枚举&#xff0c;作用就是列出一堆数值的集合&#xff0c;然后规定某个变量只能从集合中取值。例如&#xff0c;抛一个骰子&#xff0c;取值只能是1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;5&#xff0c;6&#xff1b;交通灯的颜色&#xff0c;只能是red&…