ASP.NET?Core使用功能開關(guān)控制路由訪問操作(續(xù))
前言:
在前面的文章,我們介紹了? ?使用功能開關(guān)控制路由訪問??。
但其實我們使用了2個條件做的判斷:
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(功能過濾器)可用于確定是否滿足某些條件以啟用一項功能。
功能過濾器可以自由使用任何可用的標(biāo)準(zhǔn),例如流程狀態(tài)或請求內(nèi)容。
可以為給定功能注冊功能過濾器,如果任何特征過濾器評估為真,該特征將被考慮啟用。
??在本文,我們可以判斷當(dāng)前路由地址是否為調(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???,用于獲取當(dāng)前請求上下文,然后判斷當(dāng)前路由地址是否包含??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,
? ? ? ? ? ? ? ? ? ? ? ? "無權(quán)訪問"));
? ? ? ? }
? ? ? ? await next(context);
? ? ? ? ? ??
? ? }
}然后將配置修改為如下形式:
"FeatureManagement": {
? ? "ForbiddenDebugEndpoint": {
? ? ? ? "EnabledFor": [
? ? ? ? {
? ? ? ? ? ? "Name": "DebugFeatureFilter",
? ? ? ? ? ? "Parameters": {
? ? ? ? ? ? ? ? "DebugEndpoints": [ "/test" ]
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? ]
? ? }
}結(jié)論:
運行后我們發(fā)現(xiàn),只有符合功能開關(guān)設(shè)置的路由地址才會被限制訪問:

到此這篇關(guān)于ASP.NET Core使用功能開關(guān)控制路由訪問操作(續(xù))的文章就介紹到這了,更多相關(guān)ASP.NET Core使用功能開關(guān)控制路由訪問內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用.NET 開發(fā)服務(wù)器 應(yīng)用管理工具
這篇文章主要介紹如何利用.NET 開發(fā)一個應(yīng)用管理工具的服務(wù)器,文章回先聊背景接著其是喲美好方法,需要的的小伙伴可以參考一下小面文章的具體內(nèi)容2021-10-10
為什么ASP.NET Core 數(shù)據(jù)庫連接串的值和appsettings.json配的不一樣?
這篇文章主要介紹了為什么數(shù)據(jù)庫連接串的值和appsettings.json配的不一樣?下面我們就帶著疑問閱讀下文,需要的小伙伴可以參考一下,希望對你有所幫助2022-02-02
.Net Core HttpClient處理響應(yīng)壓縮詳細(xì)
.Net Core作為后起之秀直接將HttpClient扶正,并且在此基礎(chǔ)上改良了HttpClientFactory,接下來我們就來探究一下在.Net Core中使用HttpClient處理響應(yīng)壓縮的機(jī)制。,需要的朋友可以參考下面文章的具體內(nèi)容2021-09-09
ASP.NET Web API教程 創(chuàng)建域模型的方法詳細(xì)介紹
本文將介紹幾種常見的創(chuàng)建域模型的方法,有需要的朋友可以適當(dāng)?shù)膮⒖?/div> 2012-11-11
ASP.NET MVC Web API HttpClient簡介
依稀還記得那個時候用WebClient,HttpWebRequest來發(fā)送一個請求,現(xiàn)在ASP.NET MVC4中自帶了一個類HttpClient;需要的朋友可以參考下2012-11-11
asp.net mvc路由篇 如何找到 IHttpHandler方法介紹
學(xué)習(xí)是使用asp.net已經(jīng)有很長一段時間了,現(xiàn)在就來分析一下mvc的整過過程吧。個人計劃寫一個mvc系列的博文,僅從源代碼的角度來分析mvc。在接觸mvc時我們一定會經(jīng)歷路由,那么路由這東東是怎么搞出來的啊2012-11-11
利用ASP.NET技術(shù)動態(tài)生成HTML頁面
利用ASP.NET技術(shù)動態(tài)生成HTML頁面...2006-07-07
.NET 6新特性試用Timer類之PeriodicTimer?
這篇文章主要介紹了.NET 6新特性試用Timer類之PeriodicTimer,PeriodicTimer與其他Timer需要創(chuàng)建事件回調(diào)不同,下,下面文章詳細(xì)介紹PeriodicTimer的使用方式,需要的朋友可以參考一下2022-02-02最新評論

