ASP.NET?Core使用Middleware設(shè)置有條件允許訪問路由
1.簡介
有時,我們可能在Web API中包含一些具有調(diào)試功能的請求。比如我們上次的文章中 為什么ASP.NET Core 數(shù)據(jù)庫連接串的值和appsettings.json配的不一樣?使用的獲取配置值的功能:
endpoints.MapGet("/test2/{key:alpha}", async context => { ? ? var key = context.Request.RouteValues["key"].ToString(); ? ? foreach (var provider in Configuration.Providers.Reverse()) ? ? { ? ? ? ? if (provider.TryGet(key, out string value)) ? ? ? ? { ? ? ? ? ? ? await context.Response.WriteAsync(provider.ToString()); ? ? ? ? ? ? await context.Response.WriteAsync("\r\n"); ? ? ? ? ? ? await context.Response.WriteAsync(value); ? ? ? ? ? ? break; ? ? ? ? } ? ? } });
但你絕不會想在生產(chǎn)環(huán)境中暴露它們。要想實現(xiàn)此目的,有多種方案:
- 用戶權(quán)限驗證
- 編譯成單獨dll,不發(fā)布到生產(chǎn)環(huán)境
這些方案各有利弊,這里我們介紹一種使用Middleware
實現(xiàn)的簡單方案。
2.實現(xiàn)
從上圖可以看到,請求要訪問到實際路由,需要先經(jīng)過Middleware
,我們可以在最外層的Middleware
進行檢查,只有滿足條件的請求才能通過,否則返回403錯誤。
Middleware代碼如下:
public class DebugMiddleware : IMiddleware { ? ? public async Task InvokeAsync(HttpContext context, RequestDelegate next) ? ? { ? ? ? ? var isDebugEndpoint = context.Request.Path.Value.Contains("/test"); ? ? ? ? var debugKey = context.Request.Query["debugKey"].ToString(); ? ? ? ? var debugKeyInConfig = "123456";//來自于配置 ? ? ? ? if (isDebugEndpoint && debugKey!=debugKeyInConfig) ? ? ? ? { ? ? ? ? ? ? context.SetEndpoint(new Endpoint((context) => ? ? ? ? ? ? { ? ? ? ? ? ? ? ? context.Response.StatusCode = StatusCodes.Status403Forbidden; ? ? ? ? ? ? ? ? return Task.CompletedTask; ? ? ? ? ? ? }, ? ? ? ? ? ? ? ? ? ? ? ? EndpointMetadataCollection.Empty, ? ? ? ? ? ? ? ? ? ? ? ? "無權(quán)訪問")); ? ? ? ? } ? ? ? ? await next(context); ? ? ? ? ? ?? ? ? } }
當請求地址包含“/test
”時,檢查請求參數(shù)debugKey
是否和配置的值一樣,如果不一樣就返回403錯誤。
效果如下圖:
到此這篇關(guān)于ASP.NET Core使用Middleware設(shè)置有條件允許訪問路由的文章就介紹到這了,更多相關(guān)ASP.NET Core使用Middleware有條件允許訪問路由內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在 ASP.NET Core 中自動啟用 CAP 事務(wù)詳情
本篇文章旨在描述如何在 ASP.NET Core項目中并以一種簡便的方式啟用CAP事務(wù),因為在我們的示例中都是直接演示比較直觀的方式,沒有進行封裝,有些初學者同學不太會,找到問我如何封裝,本篇文章主要基于 Entity Framework 來進行演示2021-10-10ASP.NET?Core?6最小API中使用日志和DI示例詳解
這篇文章主要為大家介紹了ASP.NET?Core?6最小API中使用日志和DI示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08.Net Core HttpClient處理響應(yīng)壓縮詳細
.Net Core作為后起之秀直接將HttpClient扶正,并且在此基礎(chǔ)上改良了HttpClientFactory,接下來我們就來探究一下在.Net Core中使用HttpClient處理響應(yīng)壓縮的機制。,需要的朋友可以參考下面文章的具體內(nèi)容2021-09-09ASP.NET Core MVC 依賴注入View與Controller
本文重點給大家介紹的是ASP.NET Core MVC 之依賴注入 View 和ASP.NET Core MVC 之依賴注入 Controller的相關(guān)資料,需要的小伙伴可以參考下面文章具體內(nèi)容2021-09-09asp.net mvc路由篇 如何找到 IHttpHandler方法介紹
學習是使用asp.net已經(jīng)有很長一段時間了,現(xiàn)在就來分析一下mvc的整過過程吧。個人計劃寫一個mvc系列的博文,僅從源代碼的角度來分析mvc。在接觸mvc時我們一定會經(jīng)歷路由,那么路由這東東是怎么搞出來的啊2012-11-11