.net 温故知新:【8】.NET 中的配置从xml转向json

一、配置概述在.net framework平台中我们常见的也是最熟悉的就是.config文件作为配置,控制台桌面程序是App.config,Web就是web.config,里面的配置格式为xml格式 。

.net 温故知新:【8】.NET 中的配置从xml转向json

文章插图
在xml里面有系统生成的配置项,也有我们自己添加的一些配置,最常用的就是appSettings节点,用来配置数据库连接和参数 。使用的话就引用包System.Configuration.ConfigurationManager 之后取里面的配置信息:System.Configuration.ConfigurationManager.AppSettings["ConnectionString"]
随着技术的发展这种配置方式显得冗余复杂,如果配置项太多层级关系参数表达凌乱,在.net core开始也将配置的格式默认成了json格式,包括现在很多的其它配置也是支持的,比如java中常用的yaml格式,为什么能支持这么多读取源和格式,其实质在于配置提供程序 。目前.NET 中的配置是使用一个或多个配置提供程序执行的 。配置提供程序使用各种配置源从键值对读取配置数据,这些配置程序稍后我们会看到,读取的配置源可以是如下这些:
  • 设置文件,appsettings.json
  • 环境变量
  • Azure Key Vault
  • Azure 应用配置
  • 命令行参数
  • 已安装或已创建的自定义提供程序
  • 目录文件
  • 内存中的 .NET 对象
  • 第三方提供程序
二、配置初识IConfiguration 接口是所有配置源的单个表示形式,给定一个或多个配置源,IConfiguration 类型提供配置数据的统一视图 。
.net 温故知新:【8】.NET 中的配置从xml转向json

文章插图
上图我们可能没有直观的感受,现在写一个例子来看看
(1). 新建控制台应用程序:创建控制台使用的是.net 6.0 框架,vs 2022 。安装Microsoft.Extensions.Configuration.Json NuGet 包,该包提供json配置文件读取 。
Install-Package Microsoft.Extensions.Configuration.Json
.net 温故知新:【8】.NET 中的配置从xml转向json

文章插图
(2). 添加appsettings.json 文件
{"person": {"name": "XSpringSun","age": 18}}(3). 使用json提供程序读取json配置new一个ConfigurationBuilder,添加json配置,AddJsonFile是在包中的IConfigurationBuilder扩展方法,其它配置提供程序也是用这种扩展方法实现 。
static void Main(string[] args){IConfiguration configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();Console.WriteLine(configuration["person:name"]);Console.WriteLine(configuration["person:age"]);Console.WriteLine("Hello, World!");Console.ReadLine();}
.net 温故知新:【8】.NET 中的配置从xml转向json

文章插图
可以看到已经取到json配置文件中的值了,配置值可以包含分层数据 。分层对象使用配置键中的 : 分隔符表示 。在下面的调试对象中我们可以看到实际configuration的Providers 提供程序数组有一个值,就是我们的JsonConfigurationProvider,并且JsonConfigurationProvider里面已经读取了json的数据存储在Data数组中 。
对于如上几行代码干了什么呢:
  • 将 ConfigurationBuilder 实例化(new ConfigurationBuilder) 。
  • 添加 "appsettings.json" 文件,由 JSON 配置提供程序识别(AddJsonFile("appsettings.json")) 。
  • 使用 configuration 实例获取所需的配置
三、选项模式这样已经实现json进行配置读取,但是取值的方式似乎和以前没什么太大变法,所以.net提供了选项模式,选项模式就是使用类来提供对相关设置组的强类型访问 。我们创建一个Config类用来转换json:
namespace ConfigDemo{public class Config{public Person? person { get; set; }}public class Person {public string? name { get; set; }public int age { get; set; }}}

经验总结扩展阅读