ASP.NET?Core使用功能開關控制路由訪問操作(續(xù))
前言:
在前面的文章,我們介紹了? ?使用功能開關控制路由訪問??。
但其實我們使用了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
(功能過濾器)可用于確定是否滿足某些條件以啟用一項功能。
功能過濾器可以自由使用任何可用的標準,例如流程狀態(tài)或請求內(nèi)容。
可以為給定功能注冊功能過濾器,如果任何特征過濾器評估為真,該特征將被考慮啟用。
??在本文,我們可以判斷當前路由地址是否為調(diào)試地址,讓評估返回真。??
二、實現(xiàn)
自定義功能過濾器實現(xiàn)代碼如下:
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<bool> EvaluateAsync(FeatureFilterEvaluationContext context) ? ? { ? ? ? ? var settings = context.Parameters.Get<DebugFeatureSettings>(); ? ? ? ? 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
??配置的值。
三、使用
修改我們上次實現(xiàn)的??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" ] ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? ] ? ? } }
結論:
運行后我們發(fā)現(xiàn),只有符合功能開關設置的路由地址才會被限制訪問:
到此這篇關于ASP.NET Core使用功能開關控制路由訪問操作(續(xù))的文章就介紹到這了,更多相關ASP.NET Core使用功能開關控制路由訪問內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
ASP.NET?Core使用Middleware設置有條件允許訪問路由
這篇文章主要介紹了ASP.NET?Core使用Middleware設置有條件允許訪問路由,文章圍繞主題相關資料展開學習內(nèi)容,需要的小伙伴可以參考一下,希望對你的學習有所幫助2022-02-02.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解
這篇文章主要為大家介紹了.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11.net程序開發(fā)IOC控制反轉(zhuǎn)和DI依賴注入詳解
這篇文章主要為大家介紹了.net程序開發(fā)IOC控制反轉(zhuǎn)和DI依賴注入示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11ASP.NET Core MVC 依賴注入View與Controller
本文重點給大家介紹的是ASP.NET Core MVC 之依賴注入 View 和ASP.NET Core MVC 之依賴注入 Controller的相關資料,需要的小伙伴可以參考下面文章具體內(nèi)容2021-09-09