[ASP.NET Core 3框架揭秘] Options[7]: 与配置系统的整合

Options[7]: 与配置系统的整合 - 图1Options模型本身与配置系统完全没有关系,但是配置在大部分情况下会作为绑定Options对象的数据源,所以有必要将两者结合在一起。与《扩展与定制》演示的两个例子一样,针对配置系统的集成同样是通过定制Options模型相应的对象来实现的

Options模型本身与配置系统完全没有关系,但是配置在大部分情况下会作为绑定Options对象的数据源,所以有必要将两者结合在一起。与《扩展与定制》演示的两个例子一样,针对配置系统的集成同样是通过定制Options模型相应的对象来实现的。具体来说,集成配置系统需要解决如下两个问题:

  • 将承载配置数据的IConfiguration对象绑定为Options对象。

  • 自动感知配置数据的变化。

第一个问题涉及针对Options对象的初始化问题,这自然是通过自定义IConfigureOptions<TOptions>实现类型来解决的,具体来说就是下面的NamedConfigureFromConfigurationOptions<TOptions>类型,它定义在NuGet包“Microsoft.Extensions.Options.ConfigurationExtensions”中。如下面的代码片段所示,NamedConfigureFromConfigurationOptions<TOptions>通过调用ConfigurationBinder的静态方法Bind利用配置绑定机制来实现配置数据向Options对象的转换。

  1. public class NamedConfigureFromConfigurationOptions<TOptions> : ConfigureNamedOptions<TOptions> where TOptions : class
  2. {
  3. public NamedConfigureFromConfigurationOptions(string name, IConfiguration config)
  4. : base(name, options => ConfigurationBinder.Bind(config, options))
  5. {}
  6. }

第二个问题则采用自定义的IOptionsChangeTokenSource<TOptions>实现类型来解决,具体提供的就是下面的ConfigurationChangeTokenSource<TOptions>。从给出的代码片段可以看出,GetChangeToken方法直接调用IConfiguration对象的GetReloadToken方法得到返回的IChangeToken对象。

  1. public class ConfigurationChangeTokenSource<TOptions> : IOptionsChangeTokenSource<TOptions>
  2. {
  3. private IConfiguration _config;
  4. public string Name { get; }
  5.  
  6. public ConfigurationChangeTokenSource(IConfiguration config) : this(Options.DefaultName, config)
  7. { }
  8. public ConfigurationChangeTokenSource(string name, IConfiguration config)
  9. {
  10. _config = config;
  11. Name = name ?? Options.DefaultName;
  12. }
  13.  
  14. public IChangeToken GetChangeToken() => _config.GetReloadToken()
  15. }

将IConfiguration对象绑定为Options对象的NamedConfigureFromConfigurationOptions<TOptions>和用来检测配置数据变化的ConfigurationChangeTokenSource<TOptions>都是通过下面的Configure<TOptions>扩展方法来注册的。

  1. public static class OptionsConfigurationServiceCollectionExtensions
  2. {
  3. public static IServiceCollection Configure<TOptions>( this IServiceCollection services, IConfiguration config) where TOptions : class
  4. => services.Configure<TOptions>(Options.Options.DefaultName, config);
  5.  
  6. public static IServiceCollection Configure<TOptions>( this IServiceCollection services, string name, IConfiguration config) where TOptions : class
  7. => services
  8. .AddSingleton<IOptionsChangeTokenSource<TOptions>>( new ConfigurationChangeTokenSource<TOptions>(name, config))
  9. .AddSingleton<IConfigureOptions<TOptions>>( new NamedConfigureFromConfigurationOptions<TOptions>(name, config));
  10. }

Options[7]: 与配置系统的整合 - 图2

作者:蒋金楠微信公众账号:大内老A微博:www.weibo.com/artech如果你想及时得到个人撰写文章以及著作的消息推送,或者想看看个人推荐的技术资料,可以扫描左边二维码(或者长按识别二维码)关注个人公众号)。本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

原文:https://www.cnblogs.com/artech/p/inside-asp-net-core-06-07.html