FeatureSelect.AspNetCore 1.0.6

dotnet add package FeatureSelect.AspNetCore --version 1.0.6                
NuGet\Install-Package FeatureSelect.AspNetCore -Version 1.0.6                
该命令旨在在 Visual Studio 的包管理器控制台中使用,因为它使用 NuGet 模块的版本 Install-Package.
<PackageReference Include="FeatureSelect.AspNetCore" Version="1.0.6" />                
对于支持 PackageReference 的项目,将此 XML 节点复制到项目文件中以引用该包。
paket add FeatureSelect.AspNetCore --version 1.0.6                
#r "nuget: FeatureSelect.AspNetCore, 1.0.6"                
#r 指令可用于 F# Interactive 和多语言笔记本。将此内容复制到交互工具或脚本的源代码中以引用包。
// Install FeatureSelect.AspNetCore as a Cake Addin
#addin nuget:?package=FeatureSelect.AspNetCore&version=1.0.6

// Install FeatureSelect.AspNetCore as a Cake Tool
#tool nuget:?package=FeatureSelect.AspNetCore&version=1.0.6                

FeatureSelect

FeatureSelect 是一个灵活的特征开关库,支持 ASP.NET Core 集成。

安装

通过 NuGet 安装

Install-Package FeatureSelect

用法

创建一个功能源并使用它来获取一个功能。一个 "功能" 包含两个函数,一个用于启用该功能时执行,一个用于禁用该功能时执行。

var source = new ConfigurationFeatureSource(Configuration);

var feature = source.GetFeature("MyFeature");

var result = feature.Execute(() => "My feature is enabled", () => "My feature is disabled");

为了与 ASP.NET Core 集成,使用 AddFeatureSelect 扩展方法在 Program.cs 中注册 FeatureSelect。

var builder = WebApplication.CreateBuilder(args);

var config = builder.Configuration;

builder.Services.AddControllers();
builder.Services.AddFeatureSelect(config.GetSection("Features"));

var app = builder.Build();

app.UseRouting();

app.MapControllers();

app.Run();

现在,您可以在控制器中使用 [IfEnabled][IfDisabled] 属性切换任何控制器或路由的开/关。

[IfEnabled("Customers")]
public class CustomerController
{
    [HttpGet("/customers")]
    [IfEnabled("GetCustomers")]
    public IActionResult Get()
    {
        ...
    }
}

您还可以注入 FeatureSource 的一个实例。

public class MyController
{
    [HttpGet("/my-feature")]
    public string Get([FromServices] FeatureSource features)
    {
        return features
            .GetFeature("MyFeature")
            .Execute(() => "My feature is enabled", () => "My feature is disabled");
    }
}

为了配置哪些功能已启用,简单地在 appsettings.json、用户密钥或环境变量中定义它们。

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    }
  },
  "AllowedHosts": "*",
  "Features": {
    "feature1": "enabled",
    "feature2": "diabled",
    "feature3": "enabled"
  }
}
产品 兼容和额外的计算目标框架版本。
.NET net5.0 已计算。 net5.0-windows 已计算。 net6.0 兼容。 net6.0-android 已计算。 net6.0-ios 已计算。 net6.0-maccatalyst 已计算。 net6.0-macos 已计算。 net6.0-tvos 已计算。 net6.0-windows 已计算。 net7.0 已计算。 net7.0-android 已计算。 net7.0-ios 已计算。 net7.0-maccatalyst 已计算。 net7.0-macos 已计算。 net7.0-tvos 已计算。 net7.0-windows 已计算。 net8.0 已计算。 net8.0-android 已计算。 net8.0-browser 已计算。 net8.0-ios 已计算。 net8.0-maccatalyst 已计算。 net8.0-macos 已计算。 net8.0-tvos 已计算。 net8.0-windows 已计算。
.NET 核心版 netcoreapp3.1 兼容。
兼容的目标框架(s)
包含的目标框架(s) (在包中)
了解有关 目标框架.NET 标准 的更多信息。

NuGet 软件包

此包没有使用任何 NuGet 软件包。

GitHub 存储库

此包没有使用任何流行的 GitHub 存储库。

版本 下载 最后更新
1.0.6 2,563 9/9/2022
1.0.5 376 9/9/2022
1.0.4 376 9/9/2022
1.0.3 380 9/8/2022
1.0.2 414 9/8/2022
1.0.1 419 9/8/2022