当前位置:首页 > Web开发 > 正文

config){ } public ConfigurationChangeTokenSource( string na

2024-03-31 Web开发

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

将承载配置数据的IConfiguration东西绑定为Options东西。

自动感知配置数据的变革。

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

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

第二个问题则给与自界说的IOptionsChangeTokenSource<TOptions>实现类型来解决,具体供给的就是下面的ConfigurationChangeTokenSource<TOptions>。从给出的代码片段可以看出,GetChangeToken要领直接挪用IConfiguration东西的GetReloadToken要领得到返回的IChangeToken东西。

public class ConfigurationChangeTokenSource<TOptions> : IOptionsChangeTokenSource<TOptions> { private IConfiguration _config; public string Name { get; } public ConfigurationChangeTokenSource(IConfiguration config) : this(Options.DefaultName, config) { } public ConfigurationChangeTokenSource(string name, IConfiguration config) { _config = config; Name = name ?? Options.DefaultName; } public IChangeToken GetChangeToken() => _config.GetReloadToken() }

将IConfiguration东西绑定为Options东西的NamedConfigureFromConfigurationOptions<TOptions>和用来检测配置数据变革的ConfigurationChangeTokenSource<TOptions>都是通过下面的Configure<TOptions>扩展要领来注册的。

public static class OptionsConfigurationServiceCollectionExtensions { public static IServiceCollection Configure<TOptions>( this IServiceCollection services, IConfiguration config) where TOptions : class => services.Configure<TOptions>(Options.Options.DefaultName, config); public static IServiceCollection Configure<TOptions>( this IServiceCollection services, string name, IConfiguration config) where TOptions : class => services .AddSingleton<IOptionsChangeTokenSource<TOptions>>( new ConfigurationChangeTokenSource<TOptions>(name, config)) .AddSingleton<IConfigureOptions<TOptions>>( new NamedConfigureFromConfigurationOptions<TOptions>(name, config)); }

[ASP.NET Core 3框架揭秘] Options[1]: 配置选项的正确使用方法[上篇]
[ASP.NET Core 3框架揭秘] Options[2]: 配置选项的正确使用方法[下篇]
[ASP.NET Core 3框架揭秘] Options[3]: Options模型[上篇]
[ASP.NET Core 3框架揭秘] Options[4]: Options模型[下篇]
[ASP.NET Core 3框架揭秘] Options[5]: 依赖注入
[ASP.NET Core 3框架揭秘] Options[6]: 扩展与定制
[ASP.NET Core 3框架揭秘] Options[7]: 与配置系统的整合

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

温馨提示: 本文由Jm博客推荐,转载请保留链接: https://www.jmwww.net/file/web/31319.html