接下来我们同样以实例的方式来演示如何定义并读取具有层次化结构的配置。我们依然沿用上一节的应用场景,现在我们不仅仅需要设置日期/时间的格式,还需要设置其他数据类型的格式,比如表示货币的Decimal类型。为此我们定义了如下一个CurrencyDecimalFormatSettings类,它的属性Digits和Symbol分别表示小数位数和货币符号,一个CurrencyDecimalFormatSettings对象依然是利用一个表示配置的Configuration对象来创建的。
{
public int Digits { get; set; }
public string Symbol { get; set; }
public CurrencyDecimalFormatSettings(IConfiguration configuration)
{
this.Digits = int.Parse(configuration["Digits"]);
this.Symbol = configuration["Symbol"];
}
}
我们定义了另一个名为FormatSettings的类型来表示针对不同数据类型的格式设置。如下面的代码片段所示,它的两个属性DateTime和CurrencyDecimal分别表示针对日期/时间和货币数字的格式设置。FormatSettings依然具有一个参数类型为IConfiguration接口的构造函数,它的两个属性均在此构造函数中被初始化。值得注意的是初始化这两个属性采用的是当前Configuration的“子配置节”,通过指定配置节名称调用GetSection方法获得。
public class FormatSettings
{
public DateTimeFormatSettings DateTime { get; set; }
public CurrencyDecimalFormatSettings CurrencyDecimal { get; set; }
public FormatSettings(IConfiguration configuration)
{
this.DateTime = new DateTimeFormatSettings(configuration.GetSection("DateTime"));
this.CurrencyDecimal = new CurrencyDecimalFormatSettings(configuration.GetSection("CurrencyDecimal"));
}
}
在我们上面演示的实例中,我们通过以一个MemoryConfigurationProvider对象来提供原始的配置信息。由于承载原始配置信息的是一个元素类型为KeyValuePair<string, string>的集合,所以原始配置在物理存储上并不具有树形化的层次结构,那么它如何能够最终提供一个结构化的Configuration对象呢?其实很简单,虽然MemoryConfigurationProvider对象只能将配置信息存储为简单的“数据字典”,但是如果将Configuration对象在配置树中体现的路径作为Key,这个数据字典在逻辑上实际上就具有了一棵树的结构。实际上MemoryConfigurationProvider就是这么做的,这体现在我们如下所示的程序之中。
class Program
{
static void Main(string[] args)
{
Dictionary<string, string> source = new Dictionary<string, string>
{
["Format:DateTime:LongDatePattern"] = "dddd, MMMM d, yyyy",
["Format:DateTime:LongTimePattern"] = "h:mm:ss tt",
["Format:DateTime:ShortDatePattern"] = "M/d/yyyy",
["Format:DateTime:ShortTimePattern"] = "h:mm tt",
["Format:CurrencyDecimal:Digits"] = "2",
["Format:CurrencyDecimal:Symbol"] = "$",
};
IConfiguration configuration = new ConfigurationBuilder()
.Add(new MemoryConfigurationProvider(source))
.Build();
FormatSettings settings = new FormatSettings(configuration.GetSection("Format"));
Console.WriteLine("DateTime:");
Console.WriteLine("t{0,-16}: {1}", "LongDatePattern", settings.DateTime.LongDatePattern);
Console.WriteLine("t{0,-16}: {1}", "LongTimePattern", settings.DateTime.LongTimePattern);
Console.WriteLine("t{0,-16}: {1}", "ShortDatePattern", settings.DateTime.ShortDatePattern);
Console.WriteLine("t{0,-16}: {1}n", "ShortTimePattern", settings.DateTime.ShortTimePattern);
Console.WriteLine("CurrencyDecimal:");
Console.WriteLine("t{0,-16}: {1}", "Digits", settings.CurrencyDecimal.Digits);
Console.WriteLine("t{0,-16}: {1}", "Symbol", settings.CurrencyDecimal.Symbol);
}
}








