您现在的位置是:网站首页> 编程资料编程资料
ASP.NET Core使用功能开关控制路由访问操作(续)_ASP.NET_
2023-05-24
297人已围观
简介 ASP.NET Core使用功能开关控制路由访问操作(续)_ASP.NET_
前言:
在前面的文章,我们介绍了 使用功能开关控制路由访问。
但其实我们使用了2个条件做的判断:
var isDebugEndpoint = context.Request.Path.Value.Contains("/test"); var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); if (isDebugEndpoint && debugEndpoint)如果仅用功能开关来控制:
var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); if (debugEndpoint)这样是不是更符合功能开关的含义呢!
一、IFeatureFilter介绍
IFeatureFilter(功能过滤器)可用于确定是否满足某些条件以启用一项功能。
功能过滤器可以自由使用任何可用的标准,例如流程状态或请求内容。
可以为给定功能注册功能过滤器,如果任何特征过滤器评估为真,该特征将被考虑启用。
在本文,我们可以判断当前路由地址是否为调试地址,让评估返回真。
二、实现
自定义功能过滤器实现代码如下:
public class DebugFeatureSettings { public string[] DebugEndpoints { get; set; } } [FilterAlias("DebugFeatureFilter")] public class DebugFeatureFilter : IFeatureFilter { private readonly IHttpContextAccessor _httpContextAccessor; public DebugFeatureFilter(IHttpContextAccessor httpContextAccessor) { _httpContextAccessor = httpContextAccessor; } public Task EvaluateAsync(FeatureFilterEvaluationContext context) { var settings = context.Parameters.Get(); foreach (var endPoint in settings.DebugEndpoints) { var isDebugEndpoint = _httpContextAccessor.HttpContext.Request.Path.Value.Contains(endPoint); return Task.FromResult(isDebugEndpoint); } return Task.FromResult(false); } } 我们注入了IHttpContextAccessor,用于获取当前请求上下文,然后判断当前路由地址是否包含DebugEndpoints配置的值。
三、使用
修改我们上次实现的DebugMiddleware:
public class DebugMiddleware : IMiddleware { private readonly IFeatureManager _featureManager; public DebugMiddleware(IFeatureManager featureManager) { _featureManager = featureManager; } public async Task InvokeAsync(HttpContext context, RequestDelegate next) { var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); if (debugEndpoint) { context.SetEndpoint(new Endpoint((context) => { context.Response.StatusCode = StatusCodes.Status403Forbidden; return Task.CompletedTask; }, EndpointMetadataCollection.Empty, "无权访问")); } await next(context); } }然后将配置修改为如下形式:
"FeatureManagement": { "ForbiddenDebugEndpoint": { "EnabledFor": [ { "Name": "DebugFeatureFilter", "Parameters": { "DebugEndpoints": [ "/test" ] } } ] } }结论:
运行后我们发现,只有符合功能开关设置的路由地址才会被限制访问:

到此这篇关于ASP.NET Core使用功能开关控制路由访问操作(续)的文章就介绍到这了,更多相关ASP.NET Core使用功能开关控制路由访问内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- ASP.NET Core使用功能开关控制路由访问操作_ASP.NET_
- 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开发环境_实用技巧_
