选项
微软引入选项模式,它是用于配置框架服务使用的设置. 选项模式由Microsoft.Extensions.OptionsNuGet包实现,除了ASP.NET Core应用,它还适用于任何类型的应用程序.
ABP框架遵循选项模式,并定义了用于配置框架和模块的选项类(在相关功能文档中有详细的说明).
由于微软的文档详细解释了选项模式,本文中只会介绍ABP增加的一些功能.
配置选项
通常配置选项在 Startup
类的 ConfigureServices
方法中. 但由于ABP框架提供了模块化基础设施,因此你可以在模块的ConfigureServices
方法配置选项. 例:
public override void ConfigureServices(ServiceConfigurationContext context)
{
context.Services.Configure<AbpAuditingOptions>(options =>
{
options.IsEnabled = false;
});
}
AbpAuditingOptions
是一个简单的类,定义了一些属性,例如这里使用的IsEnabled
.AbpModule
基类定义Configure
方法简化代码. 你可以直接使用Configure<...>
,而不是context.Services.Configure <...>
.
如果你正在开发一个可重用的模块,你可能需要定义一个允许开发人员配置模块的选项类. 这时定义一个如下所示的普通类:
public class MyOptions
{
public int Value1 { get; set; }
public bool Value2 { get; set; }
}
然后开发人员可以像上面 AbpAuditingOptions
示例一样配置你的选项:
public override void ConfigureServices(ServiceConfigurationContext context)
{
Configure<MyOptions>(options =>
{
options.Value1 = 42;
options.Value2 = true;
});
}
- 在本示例中,使用了简化的
Configure<...>
方法.
获取选项值
在你需要获得一个选项值时,将 IOptions<TOption>
服务注入到你的类中,使用它的 .Value
属性得到值. 例:
public class MyService : ITransientDependency
{
private readonly MyOptions _options;
public MyService(IOptions<MyOptions> options)
{
_options = options.Value; //Notice the options.Value usage!
}
public void DoIt()
{
var v1 = _options.Value1;
var v2 = _options.Value2;
}
}
阅读微软文档了解选择模式的所有细节.
预配置
选项模式的限制之一是你只能解析(注入) IOptions <MyOptions>
并在依赖注入配置完成(即所有模块的ConfigureServices
方法完成)后获取选项值.
如果你正在开发一个模块,可能需要让开发者能够设置一些选项,并在依赖注入注册阶段使用这些选项. 你可能需要根据选项值配置其他服务或更改依赖注入的注册代码.
对于此类情况,ABP为 IServiceCollection
引入了 PreConfigure<TOptions>
和 ExecutePreConfiguredActions<TOptions>
扩展方法. 该模式的工作原理如下所述.
在你的模块中定义预先选项类. 例:
public class MyPreOptions
{
public bool MyValue { get; set; }
}
然后任何依赖于模块的模块类都可以在其 PreConfigureServices
方法中使用 PreConfigure<TOptions>
方法. 例:
public override void PreConfigureServices(ServiceConfigurationContext context)
{
PreConfigure<MyPreOptions>(options =>
{
options.MyValue = true;
});
}
多个模块可以预配置选项,并根据它们的依赖顺序覆盖选项值.
最后在你的模块 ConfigureServices
方法中执行 ExecutePreConfiguredActions
方法来获得配置的选项值. 例:
public override void ConfigureServices(ServiceConfigurationContext context)
{
var options = context.Services.ExecutePreConfiguredActions<MyPreOptions>();
if (options.MyValue)
{
//...
}
}