您现在的位置是:网站首页> 编程资料编程资料
ASP.NET Core使用功能开关控制路由访问操作_ASP.NET_
2023-05-24
262人已围观
简介 ASP.NET Core使用功能开关控制路由访问操作_ASP.NET_
前言:
在前面的文章,我们介绍了使用Middleware有条件地允许访问路由(《ASP.NET Core使用Middleware设置有条件允许访问路由》)。
而对于一些试验性的功能,我们并不希望用密码去控制是否允许访问,而是想用一种开关的方式开放。
1.功能开关
功能开关(Feature flags)就是这样一种部署技术,有助于提高应用程序的灵活性。
使用功能开关,你可以将新功能部署到生产环境中,但限制其可用性。
通过使用开关,你可以为控制是否激活一项新功能,而无需重新启动应用程序或部署新代码。
它们将新功能的发布与代码部署分离。
3.实现
首先,我们需要引用nuget包Microsoft.FeatureManagement.AspNetCore。
然后,修改Startup.cs代码:
public void ConfigureServices(IServiceCollection services) { ... services.AddFeatureManagement(); ... }接着,增加一个配置:
"FeatureManagement": { "ForbiddenDebugEndpoint": false }3.使用
修改我们上次实现的DebugMiddleware:
public class DebugMiddleware : IMiddleware { private readonly IFeatureManager _featureManager; public DebugMiddleware(IFeatureManager featureManager) { _featureManager = featureManager; } public async Task InvokeAsync(HttpContext context, RequestDelegate next) { var isDebugEndpoint = context.Request.Path.Value.Contains("/test"); var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); if (isDebugEndpoint && debugEndpoint) { context.SetEndpoint(new Endpoint((context) => { context.Response.StatusCode = StatusCodes.Status403Forbidden; return Task.CompletedTask; }, EndpointMetadataCollection.Empty, "无权访问")); } await next(context); } }关键就是这句话,我们使用了功能开关:
var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); 结论:
运行后我们发现,只需修改配置,无需重启程序,我们就可以控制是否可以访问路由了:

到此这篇关于ASP.NET Core使用功能开关控制路由访问操作的文章就介绍到这了,更多相关ASP.NET Core使用功能开关控制路由访问内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- ASP.NET Core使用Middleware设置有条件允许访问路由_ASP.NET_
- .NET CORE 鉴权的实现示例_实用技巧_
- 为什么ASP.NET Core 数据库连接串的值和appsettings.json配的不一样?_ASP.NET_
- Net5 WorkService 继承 Quarzt 及 Net5处理文件上传功能_实用技巧_
- ASP.NET Core中的Razor页面介绍_基础应用_
- .Net Core实现第三方QQ扫码登录_实用技巧_
- .NET Core使用APB vNext框架入门教程_实用技巧_
- .NET Core使用Autofac容器的DI依赖注入,IOC控制反转及AOP切面编程_实用技巧_
- Ubuntu16.04系统搭建.Net Core开发环境_实用技巧_
- ASP.NET Core扩展库ServiceStack.Redis用法介绍_实用技巧_
