为什么应该在业务层实现管道模式,而不用ASP.NET Core Middleware实现 | 2点原因和实现方式...
前言
ASP.NET Core的Middleware(中間件)就是使用了管道模式:
Request(請求)在管道中傳遞,依次經過管道中的每一個MiddleWare進行處理。
MiddleWare就像一層層的“濾網”,過濾所有的請求和響應。
這種模式的好處在于,分離關注點。比如驗證用戶、記錄訪問日志,可以將這些任務分解到不同MiddleWare中,互相解耦。
既然ASP.NET Core已經實現了管道模式,為什么還要在業務層實現一遍呢?
原因
我覺得可以分為2方面考慮:
與頂級框架解耦,不能保證應用程序代碼始終運行在ASP.NET Core下,如果將業務遷移到WPF,記錄訪問日志這類放在管道中的功能還是需要實現
同時支持不同來源請求,請求可能來自于Web API,也可能來自于Windows Service定時調用,但業務層處理邏輯應保持一樣
因此,ASP.NET Core框架應該只用于接收輸入和返回輸出,而在業務層實現管道模式。
定義API的最佳實踐
在《定義API的最佳實踐MediatR類庫實現Controller方法,將業務邏輯和Controller進行隔離。
示例代碼如下:
[HttpGet] public?async?Task<string>?Demo([FromQuery]?DemoQuery?request) {return?await?_mediator.Send(request); }public?class?DemoQuery?:?IRequest<string> {public?string?Name?{?get;?set;?} }public?class?DemoQueryHandler?:?IRequestHandler<DemoQuery,?string> {?public?async?Task<string>?Handle(DemoQuery?request,?CancellationToken?cancellationToken){Console.WriteLine("DemoQueryHandler執行");return?request.Name;} }而MediatR不僅僅是一個簡單的中介模式實現,它還提供了Behaviors的概念:
Behaviors非常類似于ASP.NET Core中的MiddleWare,可以讓我們實現管道模式。
管道實現
要定義Behaviors,我們需要實現IPipelineBehavior接口,示例代碼如下:
public?class?FirstPipelineBehavior<TRequest,?TResponse>:?IPipelineBehavior<TRequest,?TResponse> {public?async?Task<TResponse>?Handle(TRequest?request,?CancellationToken?cancellationToken,?RequestHandlerDelegate<TResponse>?next){Console.WriteLine("FirstPipelineBehavior執行中");var?response?=?await?next();Console.WriteLine("FirstPipelineBehavior執行完成");return?response;} }和MiddleWare類似,調用next()可以將請求向下傳遞。
接著在Startup.cs中注冊管道:
services.AddMediatR(typeof(Startup)); services.AddTransient(typeof(IPipelineBehavior<,>),?typeof(FirstPipelineBehavior<,>)); services.AddTransient(typeof(IPipelineBehavior<,>),?typeof(SecondPipelineBehavior<,>)); services.AddTransient(typeof(IPipelineBehavior<,>),?typeof(ThirdPipelineBehavior<,>));訪問API可以看到,管道可以在IRequestHandler執行之前和之后執行代碼,并且處理順序和注冊順序相同:
結論
通過本文,我們了解到,通過MediatR提供的Behaviors功能,不依賴ASP.NET Core框架,可以在業務層實現管道模式。
如果你覺得這篇文章對你有所啟發,請關注我的個人公眾號”My IO“,記住我!
總結
以上是生活随笔為你收集整理的为什么应该在业务层实现管道模式,而不用ASP.NET Core Middleware实现 | 2点原因和实现方式...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 03Prism WPF 入门实战 - R
- 下一篇: C# 选中 DataGridView 控