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 ...
随机推荐
- 聊起 BigTable,让你不再胆怯
谷歌“三驾马车”的出现,才真正把我们带入了大数据时代,并指明了大数据的发展方向. GFS 作为其中一驾宝车,解决了大数据存储的难题.它能够把大量廉价的普通机器,聚在一起,充分让每台廉价的机器发挥光和热 ...
- C语言:static关键字用法
参考博客:https://blog.csdn.net/guotianqing/article/details/79828100 看个例子: #include <stdio.h> void ...
- node.js代码
// 1. 引入 express var express = require('express'); var formidable = require('formidable'); var mysql ...
- 基于 mpvue 框架的小程序选择控件,支持单列,多列,联动
最近在学着写mpvue小程序,在做选择控件时候遇到了点问题,按照微信小程序方法picker,很不方便! 在网上搜到一个很好用的组件下面给大家分享: 组件说明文档链接:https://go.ctolib ...
- Java第三十三天,IO操作(续集),字符转换流
计算机都是以二进制码格式存储文件的,但是在读写文件的过程中,每个应用程序都有自己的编码格式.FileWrite和FileRead类是通过查询系统默认码表进行读写的,因此在自己的系统上能够实现编码的智能 ...
- 【Tool】Windows系统安装Maven依赖管理工具
安装Maven依赖管理工具 官网下载地址:http://maven.apache.org/download.cgi 系统环境要求: [JDK]Maven3.3版本+需要JDK1.7版本以上支持 [内存 ...
- L8梯度消失、梯度爆炸
houseprices数据下载: 链接:https://pan.baidu.com/s/1-szkkAALzzJJmCLlJ1aXGQ 提取码:9n9k 梯度消失.梯度爆炸以及Kaggle房价预测 代 ...
- The equation SGU - 106
题目链接:https://codeforces.com/problemsets/acmsguru/problem/99999/106 这个题是关于EXGCD特别好的一个题目.题目大意:有一个等式ax+ ...
- vue项目中使用bpmn-节点篇
前情提要 根据之前的操作,我们可以创建.导入.导出流程图,并对其进预览.通过此篇可以学到: 为节点添加点击.鼠标悬浮等事件 获取流程图内所有指定类型的节点 通过外部更新节点名字 获取节点实例的两种方法 ...
- api测试用例(编写思路)
在API的自动化测试维度中,测试维度分为两个维度,一个是单独的对API的验证,客户端发送一个请求后,服务端得到客户端的请求并且响应回复给客户端: 另外一个维度是基于业务场景的测试,基于业务场景的也就是 ...