ASP.NET?Core使用功能開關(guān)控制路由訪問操作(續(xù))
前言:
在前面的文章,我們介紹了? ?使用功能開關(guān)控制路由訪問??。
但其實(shí)我們使用了2個(gè)條件做的判斷:
var isDebugEndpoint = context.Request.Path.Value.Contains("/test"); var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); if (isDebugEndpoint && debugEndpoint)
如果僅用功能開關(guān)來控制:
var debugEndpoint = await _featureManager.IsEnabledAsync("ForbiddenDebugEndpoint"); if (debugEndpoint)
這樣是不是更符合功能開關(guān)的含義呢!
一、IFeatureFilter介紹
IFeatureFilter
(功能過濾器)可用于確定是否滿足某些條件以啟用一項(xiàng)功能。
功能過濾器可以自由使用任何可用的標(biāo)準(zhǔn),例如流程狀態(tài)或請(qǐng)求內(nèi)容。
可以為給定功能注冊(cè)功能過濾器,如果任何特征過濾器評(píng)估為真,該特征將被考慮啟用。
??在本文,我們可以判斷當(dāng)前路由地址是否為調(diào)試地址,讓評(píng)估返回真。??
二、實(shí)現(xiàn)
自定義功能過濾器實(shí)現(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
???,用于獲取當(dāng)前請(qǐng)求上下文,然后判斷當(dāng)前路由地址是否包含??DebugEndpoints
??配置的值。
三、使用
修改我們上次實(shí)現(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, ? ? ? ? ? ? ? ? ? ? ? ? "無權(quán)訪問")); ? ? ? ? } ? ? ? ? await next(context); ? ? ? ? ? ?? ? ? } }
然后將配置修改為如下形式:
"FeatureManagement": { ? ? "ForbiddenDebugEndpoint": { ? ? ? ? "EnabledFor": [ ? ? ? ? { ? ? ? ? ? ? "Name": "DebugFeatureFilter", ? ? ? ? ? ? "Parameters": { ? ? ? ? ? ? ? ? "DebugEndpoints": [ "/test" ] ? ? ? ? ? ? } ? ? ? ? } ? ? ? ? ] ? ? } }
結(jié)論:
運(yùn)行后我們發(fā)現(xiàn),只有符合功能開關(guān)設(shè)置的路由地址才會(huì)被限制訪問:
到此這篇關(guān)于ASP.NET Core使用功能開關(guān)控制路由訪問操作(續(xù))的文章就介紹到這了,更多相關(guān)ASP.NET Core使用功能開關(guān)控制路由訪問內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP.NET?Core使用Middleware設(shè)置有條件允許訪問路由
這篇文章主要介紹了ASP.NET?Core使用Middleware設(shè)置有條件允許訪問路由,文章圍繞主題相關(guān)資料展開學(xué)習(xí)內(nèi)容,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助2022-02-02.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解
這篇文章主要為大家介紹了.Net 7函數(shù)Ctor與CCtor使用及區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11.net程序開發(fā)IOC控制反轉(zhuǎn)和DI依賴注入詳解
這篇文章主要為大家介紹了.net程序開發(fā)IOC控制反轉(zhuǎn)和DI依賴注入示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11ASP.NET學(xué)習(xí)中常見錯(cuò)誤總結(jié)歸納
這篇文章主要介紹了asp.net學(xué)習(xí)過程中碰到的常見錯(cuò)誤的解決方法,通讀本篇對(duì)大家的學(xué)習(xí)或工作具有一定的價(jià)值,需要的朋友可以參考下2021-09-09ASP.NET Core MVC 依賴注入View與Controller
本文重點(diǎn)給大家介紹的是ASP.NET Core MVC 之依賴注入 View 和ASP.NET Core MVC 之依賴注入 Controller的相關(guān)資料,需要的小伙伴可以參考下面文章具體內(nèi)容2021-09-09