ASP.NET Core如何设置有条件允许访问路由(asp.net,core,开发技术)

时间:2024-04-29 19:47:21 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

1.简介

有时,我们可能在Web API中包含一些具有调试功能的请求。比如我们上次的文章中 为什么ASP.NETCore数据库连接串的值和appsettings.json配的不一样?使用的获取配置值的功能:

endpoints.MapGet("/test2/{key:alpha}",asynccontext=>{varkey=context.Request.RouteValues["key"].ToString();foreach(varproviderinConfiguration.Providers.Reverse()){if(provider.TryGet(key,outstringvalue)){awaitcontext.Response.WriteAsync(provider.ToString());awaitcontext.Response.WriteAsync("\r\n");awaitcontext.Response.WriteAsync(value);break;}}});

但你绝不会想在生产环境中暴露它们。要想实现此目的,有多种方案:

  • 用户权限验证

  • 编译成单独dll,不发布到生产环境

这些方案各有利弊,这里我们介绍一种使用Middleware实现的简单方案。

2.实现

ASP.NET Core如何设置有条件允许访问路由

从上图可以看到,请求要访问到实际路由,需要先经过Middleware,我们可以在最外层的Middleware进行检查,只有满足条件的请求才能通过,否则返回403错误。

Middleware代码如下:

publicclassDebugMiddleware:IMiddleware{publicasyncTaskInvokeAsync(HttpContextcontext,RequestDelegatenext){varisDebugEndpoint=context.Request.Path.Value.Contains("/test");vardebugKey=context.Request.Query["debugKey"].ToString();vardebugKeyInConfig="123456";//来自于配置if(isDebugEndpoint&&debugKey!=debugKeyInConfig){context.SetEndpoint(newEndpoint((context)=>{context.Response.StatusCode=StatusCodes.Status403Forbidden;returnTask.CompletedTask;},EndpointMetadataCollection.Empty,"无权访问"));}awaitnext(context);}}

当请求地址包含“/test”时,检查请求参数debugKey是否和配置的值一样,如果不一样就返回403错误。

效果如下图:

ASP.NET Core如何设置有条件允许访问路由

 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:ASP.NET Core如何设置有条件允许访问路由的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:ASP.NET Core中如何使用功能开关控制路由访问下一篇:

2 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18