dotnetcore配置框架简介
一、前言
配置的本质就是字符串的键值对,微软的一系列接口其实就是对这些键值对字符串的抽象。
二、基本类型
2.1、Nuget包
- Microsoft.Extensions.Configuration.Abstractions
- Microsoft.Extensions.Configuration
2.2、抽象接口
- IConfiguration
- 提供了查询、设置配置项、监控变化等方法
- IConfigurationRoot
- 在IConfiguration接口基础上,增加了 Reload 方法强制从provider中重新加载配置值
- IConfigurationSection
- 对配置节点的抽象
- IConfigurationBuilder
- 根据提供的数据源注册并构建IConfiguration
- IConfigurationSource
- 对数据源的抽象,例如Json、xml、环境变量、内存变量等
- IConfigurationProvider
- 规定了配置项的获取、设置、重载等统一的行为
三、基本配置
注:各种配置方式的目的是在控制台中输出以下内容,如下图:

3.1、加载内存中的配置
- 需要引入包:Microsoft.Extensions.Configuration
- 主要方法:builder.AddInMemoryCollection()
static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
var memoryData = new Dictionary<string, string>();
memoryData.Add("Student:Code", "");
memoryData.Add("Student:Name", "LiuSan"); builder.AddInMemoryCollection(memoryData);
IConfigurationRoot configurationRoot = builder.Build();
IConfigurationSection configurationSection = configurationRoot.GetSection("Student"); Console.WriteLine($"Code:{configurationSection["Code"]}");
Console.WriteLine($"Name:{configurationSection["Name"]}"); Console.Read();
}
3.2、加载环境变量中的配置
- 需要引入包:Microsoft.Extensions.Configuration.EnvironmentVariables
- 主要方法:builder.AddEnvironmentVariables()
- 环境变量中层级关系使用 __ 代替 :

static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddEnvironmentVariables();
IConfigurationRoot configurationRoot = builder.Build();
IConfigurationSection configurationSection = configurationRoot.GetSection("Student"); Console.WriteLine($"Code:{configurationSection["Code"]}");
Console.WriteLine($"Name:{configurationSection["Name"]}"); Console.Read();
}
3.3、加载命令行中的配置
- 需要引入包:Microsoft.Extensions.Configuration.CommandLine
- 主要方法:builder.AddCommandLine(args)
- 命令行中使用--表示配置项,层级关系使用:

static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddCommandLine(args);
IConfigurationRoot configurationRoot = builder.Build();
IConfigurationSection configurationSection = configurationRoot.GetSection("Student"); Console.WriteLine($"Code:{configurationSection["Code"]}");
Console.WriteLine($"Name:{configurationSection["Name"]}"); Console.Read();
}
3.4、加载Json中的配置
- 需要引入包:Microsoft.Extensions.Configuration.Json
- 主要方法:builder.AddJsonFile("appsettings.json")

static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddJsonFile("appsettings.json");
IConfigurationRoot configurationRoot = builder.Build();
IConfigurationSection configurationSection = configurationRoot.GetSection("Student"); Console.WriteLine($"Code:{configurationSection["Code"]}");
Console.WriteLine($"Name:{configurationSection["Name"]}"); Console.Read();
}
3.5、加载xml中的配置
- 需要引入包:Microsoft.Extensions.Configuration.Xml
- 主要方法:builder.AddXmlFile("appsettings.xml")
- xml中不会读取最外层,所以Section必需从第二层开始

static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddXmlFile("appsettings.xml");
IConfigurationRoot configurationRoot = builder.Build();
IConfigurationSection configurationSection = configurationRoot.GetSection("Student"); Console.WriteLine($"Code:{configurationSection["Code"]}");
Console.WriteLine($"Name:{configurationSection["Name"]}"); Console.Read();
}
四、高级配置
4.1、将配置绑定至强对象
- 需要引入包:Microsoft.Extensions.Configuration.Binder
- 主要方法:configurationRoot.GetSection("Student").Bind(student)
class Program
{
static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddJsonFile("appsettings.json");
IConfigurationRoot configurationRoot = builder.Build(); var student = new Student();
configurationRoot.GetSection("Student").Bind(student); Console.WriteLine($"Code:{student.Code}");
Console.WriteLine($"Name:{student.Name}"); Console.Read();
}
} class Student
{
public string Code { get; set; } public string Name { get; set; }
}
4.2、IOptions
- 需要引入包:Microsoft.Extensins.Options
- 需要引入包:Microsoft.Extensions.Options.ConfigurationExtensions
- 本质其实就是将一个Section配置节点映射到一个实体对象

class Program
{
static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddJsonFile("appsettings.json");
IConfigurationRoot configurationRoot = builder.Build(); IServiceCollection services = new ServiceCollection();
services.Configure<WeixinOptions>(configurationRoot.GetSection("WeixinSetting"));
services.AddScoped<IWeixinService, WeixinService>(); var provider = services.BuildServiceProvider();
var weixinService = provider.GetService<IWeixinService>();
string appId = weixinService.AppId;
string token = weixinService.Token; Console.Read();
}
} interface IWeixinService
{
string AppId { get; }
string Token { get; }
} class WeixinService: IWeixinService
{
IOptions<WeixinOptions> _options;
public WeixinService(IOptions<WeixinOptions> options)
{
_options = options;
} public string AppId { get => _options.Value.AppId; }
public string Token { get => _options.Value.Token;}
} class WeixinOptions
{
public string AppId { get; set; } public string Token { get; set; }
}
4.3、热更新
- IConfigurationBuilder添加数据源时设置reloadOnChange=true
- 监听的核心方法:var token = configurationRoot.GetReloadToken()
static void Main(string[] args)
{
IConfigurationBuilder builder = new ConfigurationBuilder();
builder.AddJsonFile("appsettings.json", optional:false, reloadOnChange:true);
IConfigurationRoot configurationRoot = builder.Build();
IConfigurationSection configurationSection = configurationRoot.GetSection("Student"); var token = configurationRoot.GetReloadToken();
ChangeToken.OnChange(() => configurationRoot.GetReloadToken(), () =>
{
Console.WriteLine("配置发生改变了...");
Console.WriteLine($"Code:{configurationSection["Code"]}");
Console.WriteLine($"Name:{configurationSection["Name"]}");
}); Console.Read();
}
五、总结
- 配置就是key-value键值对字符串
- IConfiguration和IConfigurationRoot是对键值对的抽象
- IConfigurationBuilder用于构建IConfiguration和IConfigurationRoot
- IConfigurationSource是对数据源的抽象
- IConfigurationProvider将不同来源的IConfigurationSource 转为统一的模型
- IOptions方便将不同的配置节点(Path)映射为对应的强类型对象
- IConfigurationBuilder添加多个数据源(IConfigurationSource)后,如果key重名,则以最后一个配置为准(覆盖前面)
更多精彩文章,请关注我的公众号:

dotnetcore配置框架简介的更多相关文章
- Spring笔记——Spring框架简介和初次框架配置
Spring简介 Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J2EE Deve ...
- Spring 系列: Spring 框架简介 -7个部分
Spring 系列: Spring 框架简介 Spring AOP 和 IOC 容器入门 在这由三部分组成的介绍 Spring 框架的系列文章的第一期中,将开始学习如何用 Spring 技术构建轻量级 ...
- 《HiWind企业快速开发框架实战》(0)目录及框架简介
<HiWind企业快速开发框架实战>(0)目录及框架简介 本系列主要介绍一款企业管理系统快速开发框架,该框架旨在快速完成企业管理系统,并实现易维护可移植的目标. 使用逐个系统模块进行编码的 ...
- Yaf零基础学习总结1-Yaf框架简介
从今天开始,给大家讲解下yaf框架,讲解之前肯定要了解下yaf是个什么东西,当然,从标题我们已经知道yaf是个PHP框架了,也许大家对于PHP框架并不陌生,一般PHP程序员用过的框架至少有一两个吧,国 ...
- Spring 系列: Spring 框架简介(转载)
Spring 系列: Spring 框架简介 http://www.ibm.com/developerworks/cn/java/wa-spring1/ Spring AOP 和 IOC 容器入门 在 ...
- 依赖注入及AOP简述(四)——“好莱坞原则”和依赖注入框架简介 .
3.2. “好莱坞原则” 看了前面关于依赖注入概念的描述,我们来提炼出依赖注入的核心思想.如果说传统的组件间耦合方式,例如new.工厂模式等,是一种由开发者主动去构建依赖对象的话,那么依赖注入模 ...
- 轻量级ORM框架 QX_Frame.Bantina(一、框架简介)
轻量级ORM框架QX_Frame.Bantina系列讲解(开源) 一.框架简介 http://www.cnblogs.com/qixiaoyizhan/p/7417467.html 二.框架使用方式介 ...
- JAVAEE——BOS物流项目10:权限概述、常见的权限控制方式、apache shiro框架简介、基于shiro框架进行认证操作
1 学习计划 1.演示权限demo 2.权限概述 n 认证 n 授权 3.常见的权限控制方式 n url拦截权限控制 n 方法注解权限控制 4.创建权限数据模型 n 权限表 n 角色表 n 用户表 n ...
- Rafy 领域实体框架简介
按照最新的功能,更新了最新版的<Rafy 领域实体框架的介绍>,内容如下: 本文包含以下章节: 简介 特点 优势 简介 Rafy 领域实体框架是一个轻量级 ORM 框架. 与一般的 ORM ...
随机推荐
- javascript原生 实现数字字母混合验证码
实现4位数 数字字母混合验证码(数字+大写字母+小写字母) ASCII 字符集中得到3个范围: 1. 48-57 表示数字0-9 2. 65-90 表示大写字母 3. 97-122 表示小写字母 范围 ...
- Python——详解__str__, __repr__和__format__
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Python专题的第10篇文章,我们来聊聊Python当中的类. 打印实例 我们先从类和对象当中最简单的打印输出开始讲起,打印一个实例 ...
- Hadoop在Ubuntu的安装和使用
由于小编在本学期有一门课程需要学习hadoop,需要在ubuntu的linux系统下搭建Hadoop环境,在这个过程中遇到一些问题,写下这篇博客来记录这个过程,并把分享给大家. Hadoop的安装方式 ...
- Spring+Hibernate整合配置 --- 比较完整的spring、hibernate 配置
Spring+Hibernate整合配置 分类: J2EE2010-11-25 17:21 16667人阅读 评论(1) 收藏 举报 springhibernateclassactionservlet ...
- 小程序以及H5页面上IphoneX底部安全区域小黑条适配问题
背景 公司项目开发中,发现iPhoneX上吸底元素存在被小黑条遮挡的问题 原因 在苹果 iPhoneX .iPhone XR等机型上,物理Home键被取消,改为底部小黑条替代home键功能,从而导致吸 ...
- css定位有哪几种方式
一.position 属性规定元素的定位类型,它一般有以下四个值: 默认static 相对定位relative 绝对定位absolute 固定定位fixed 元素可以使用的顶部,底部,左侧和右侧属性定 ...
- AJ学IOS(05)UI之360等下载管理器九宫格UI
AJ分享,必须精品 先看效果 主要是完成了九宫格UI的搭建 代码 - (void)viewDidLoad { [super viewDidLoad]; //九宫格中每个格子的宽 #define kAp ...
- centos7用户管理及root忘记密码恢复
查看用户相关命令:#id 用户和组的信息#whoami #查看当前有效用户名#who #显示目前登入系统的用户信息.#w # w 命令用于显示已经登陆系统的用户列表#users #用于显示当前登录系统 ...
- 绝地求生模拟登陆!高难度JS解密教程,Python高级爬虫开发,
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取htt ...
- stand up meeting 11/20/2015
3组员 今日工作 工作耗时/h 明日计划 计划耗时/h 冯晓云 将输出string里的翻译合理取分为动名词等各种词性,按约定格式返回,按热度排列,但每一个词性下的解释仍然是由“$$”分词:对于查询词为 ...