ASP.NET Core使用功能开关控制路由访问
生活随笔
收集整理的這篇文章主要介紹了
ASP.NET Core使用功能开关控制路由访问
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
前言
在前面的文章,我們介紹了使用Middleware有條件地允許訪問路由(《ASP.NET Core使用Middleware有條件地允許訪問路由》)。
而對于一些試驗性的功能,我們并不希望用密碼去控制是否允許訪問,而是想用一種開關的方式開放。
功能開關
功能開關(Feature flags)就是這樣一種部署技術,有助于提高應用程序的靈活性。
使用功能開關,你可以將新功能部署到生產環境中,但限制其可用性。
通過使用開關,你可以為控制是否激活一項新功能,而無需重新啟動應用程序或部署新代碼。
它們將新功能的發布與代碼部署分離。
實現
首先,我們需要引用nuget包Microsoft.FeatureManagement.AspNetCore。
然后,修改Startup.cs代碼:
public?void?ConfigureServices(IServiceCollection?services) {...services.AddFeatureManagement();... }接著,增加一個配置:
"FeatureManagement":?{"ForbiddenDebugEndpoint":?false}使用
修改我們上次實現的DebugMiddleware:
public?class?DebugMiddleware?:?IMiddleware {private?readonly?IFeatureManager?_featureManager;public?DebugMiddleware(IFeatureManager?featureManager){_featureManager?=?featureManager;}public?async?Task?InvokeAsync(HttpContext?context,?RequestDelegate?next){var?isDebugEndpoint?=?context.Request.Path.Value.Contains("/test");var?debugEndpoint?=?await?_featureManager.IsEnabledAsync("ForbiddenDebugEndpoint");if?(isDebugEndpoint?&&?debugEndpoint){context.SetEndpoint(new?Endpoint((context)?=>{context.Response.StatusCode?=?StatusCodes.Status403Forbidden;return?Task.CompletedTask;},EndpointMetadataCollection.Empty,"無權訪問"));}await?next(context);} }關鍵就是這句話,我們使用了功能開關:
var?debugEndpoint?=?await?_featureManager.IsEnabledAsync("ForbiddenDebugEndpoint");結論
運行后我們發現,只需修改配置,無需重啟程序,我們就可以控制是否可以訪問路由了:
想了解更多內容,請關注我的個人公眾號”My IO“
總結
以上是生活随笔為你收集整理的ASP.NET Core使用功能开关控制路由访问的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C# 使用多个异步方法
- 下一篇: ASP.NET Core使用功能开关控制