ASP.NET?Core使用Middleware設(shè)置有條件允許訪問(wèn)路由
1.簡(jiǎn)介
有時(shí),我們可能在Web API中包含一些具有調(diào)試功能的請(qǐng)求。比如我們上次的文章中 為什么ASP.NET Core 數(shù)據(jù)庫(kù)連接串的值和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;
? ? ? ? }
? ? }
});但你絕不會(huì)想在生產(chǎn)環(huán)境中暴露它們。要想實(shí)現(xiàn)此目的,有多種方案:
- 用戶(hù)權(quán)限驗(yàn)證
- 編譯成單獨(dú)dll,不發(fā)布到生產(chǎn)環(huán)境
這些方案各有利弊,這里我們介紹一種使用Middleware實(shí)現(xiàn)的簡(jiǎn)單方案。
2.實(shí)現(xiàn)

從上圖可以看到,請(qǐng)求要訪問(wèn)到實(shí)際路由,需要先經(jīng)過(guò)Middleware,我們可以在最外層的Middleware進(jìn)行檢查,只有滿足條件的請(qǐng)求才能通過(guò),否則返回403錯(cuò)誤。
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";//來(lái)自于配置
? ? ? ? if (isDebugEndpoint && debugKey!=debugKeyInConfig)
? ? ? ? {
? ? ? ? ? ? context.SetEndpoint(new Endpoint((context) =>
? ? ? ? ? ? {
? ? ? ? ? ? ? ? context.Response.StatusCode = StatusCodes.Status403Forbidden;
? ? ? ? ? ? ? ? return Task.CompletedTask;
? ? ? ? ? ? },
? ? ? ? ? ? ? ? ? ? ? ? EndpointMetadataCollection.Empty,
? ? ? ? ? ? ? ? ? ? ? ? "無(wú)權(quán)訪問(wèn)"));
? ? ? ? }
? ? ? ? await next(context);
? ? ? ? ? ??
? ? }
}當(dāng)請(qǐng)求地址包含“/test”時(shí),檢查請(qǐng)求參數(shù)debugKey是否和配置的值一樣,如果不一樣就返回403錯(cuò)誤。
效果如下圖:

到此這篇關(guān)于ASP.NET Core使用Middleware設(shè)置有條件允許訪問(wèn)路由的文章就介紹到這了,更多相關(guān)ASP.NET Core使用Middleware有條件允許訪問(wèn)路由內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- ASP.NET?Core使用功能開(kāi)關(guān)控制路由訪問(wèn)操作
- Asp.net Core 如何設(shè)置黑白名單(路由限制)
- ASP.NET Core自動(dòng)生成小寫(xiě)破折號(hào)路由的實(shí)現(xiàn)方法
- ASP.NET Core3.1 Ocelot路由的實(shí)現(xiàn)
- ASP.NET Core中自定義路由約束的實(shí)現(xiàn)
- 詳解ASP.NET Core 2.0 路由引擎之網(wǎng)址生成(譯)
- ASP.NET Core Razor 頁(yè)面路由詳解
- ASP.NET?Core使用功能開(kāi)關(guān)控制路由訪問(wèn)操作(續(xù))
相關(guān)文章
ASP.NET學(xué)習(xí)中常見(jiàn)錯(cuò)誤總結(jié)歸納
這篇文章主要介紹了asp.net學(xué)習(xí)過(guò)程中碰到的常見(jiàn)錯(cuò)誤的解決方法,通讀本篇對(duì)大家的學(xué)習(xí)或工作具有一定的價(jià)值,需要的朋友可以參考下2021-09-09
.NET?中配置從xml轉(zhuǎn)向json方法示例詳解
這篇文章主要為大家介紹了.NET?中配置從xml轉(zhuǎn)向json方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
ASP.NET Core如何注入多個(gè)服務(wù)實(shí)現(xiàn)類(lèi)
這篇文章主要介紹了ASP.NET Core如何注入多個(gè)服務(wù)實(shí)現(xiàn)類(lèi)的相關(guān)資料,需要的朋友可以參考下面文章的具體內(nèi)容2021-09-09
asp.net core使用DevExtreme20將int列轉(zhuǎn)為checkbox方法示例
這篇文章主要為大家介紹了asp.net core使用DevExtreme20將int列轉(zhuǎn)為checkbox方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
修改 asp.net core 5 程序的默認(rèn)端口號(hào)
這篇文章主要介紹了修改 asp.net core 5 程序的默認(rèn)端口號(hào),我們知道可以通過(guò)修改 launchSettings.json 文件中的端口號(hào)來(lái)實(shí)現(xiàn)端口切換,下面來(lái)看看具體的修改過(guò)程吧2022-01-01
.NET?Core?中對(duì)象池?Object?Pool的使用
這篇文章主要介紹了?.NET?Core?中對(duì)象池?Object?Pool的使用,對(duì)象池簡(jiǎn)單來(lái)說(shuō)就是一種為對(duì)象提供可復(fù)用能力的軟件設(shè)計(jì)思路,對(duì)象池最常用的場(chǎng)景是游戲設(shè)計(jì),因?yàn)樵谟螒蛑写罅看嬖谥蓮?fù)用的對(duì)象,源源不斷的子彈出現(xiàn)并不是循環(huán)再生的,下面一起進(jìn)入文章了解具體內(nèi)容吧2021-11-11
ASP.NET Web API教程 創(chuàng)建域模型的方法詳細(xì)介紹
本文將介紹幾種常見(jiàn)的創(chuàng)建域模型的方法,有需要的朋友可以適當(dāng)?shù)膮⒖?/div> 2012-11-11最新評(píng)論

