为了账号安全,请及时绑定邮箱和手机立即绑定

ASP.NET Core MVC 入门到精通 - 3. 使用MediatR

标签:
.NET

环境:

.NET 5
ASP.NET Core MVC (project)

  1. MediatR
    MediatR .NET中的简单中介者模式实现,一种进程内消息传递机制(无其他外部依赖)。支持以同步或异步的形式进行请求/响应,命令,查询,通知和事件的消息传递,并通过C#泛型支持消息的智能调度。

Simple mediator implementation in .NET
In-process messaging with no dependencies.
Supports request/response, commands, queries, notifications and events, synchronous and async with intelligent dispatching via C# generic variance.

另:中介者模式 - 定义一个中介对象来封装一系列对象之间的交互,使原有对象之间的耦合松散,且可以独立地改变它们之间的交互。中介者模式又叫调停模式,它是迪米特法则的典型应用。

  1. 安装 & 配置
    对于.NET5 (.net core), 使用nuget 安装MediatR.Extensions.Microsoft.DependencyInjection.

配置:

public void ConfigureServices(IServiceCollection services)
{
services.AddControllersWithViews();
services.AddMediatR(typeof(Startup));
}
3. MediatR消息类型
3.1. Notifications 通知模式
Notifications 通知模式用于生产者发送通知,消费者(可以多个)接收到通知后,进行后续处理。
例:一个APS.NET 页面,访问时,发送Notifications通知;消费者简单记录收到通知的时间。

3.1.1. 定义基于INotification的通知类
public class Ping : INotification { }
3.1.2. 定义消费者(关注通知的处理方法)
public class Pong1 : INotificationHandler
{
public Task Handle(Ping notification, CancellationToken cancellationToken)
{
Debug.WriteLine($“Pong1, {DateTime.Now}”);
return Task.CompletedTask;
}
}

public class Pong2 : INotificationHandler
{
public Task Handle(Ping notification, CancellationToken cancellationToken)
{
Debug.WriteLine($“Pong2, {DateTime.Now}”);
return Task.CompletedTask;
}
}
3.1.3. 发送消息通知
// 基于dotnet core的依赖注入,注入IMediator对象
private readonly IMediator _mediator;
public HomeController(ILogger logger, IMediator mediator)
{
_logger = logger;
_mediator = mediator;
}

public async Task IndexAsync()
{
// e.g. 访问首页时,发送通知
await _mediator.Publish(new Ping());
return View();
}
3.1.4. 输出
Pong1, 5/27/2021 4:37:18 PM
Pong2, 5/27/2021 4:37:18 PM

3.2. Request/Response 请求响应模式
request/response用于命令和查询的场景。

3.2.1. 创建请求类:
public class RequestModel: IRequest
{
}
3.2.2. 创建请求处理类
不同于通知模式,request/response只能有一个请求处理。

public class RequestHandeler : IRequestHandler<RequestModel, string>
{
public Task Handle(RequestModel request, CancellationToken cancellationToken)
{
return Task.FromResult($“Pong {DateTime.Now}”); // 测试,返回内容给request
}
}
3.2.3. 页面中发送请求
private readonly ILogger _logger;
private readonly IMediator _mediator;

public HomeController(ILogger logger, IMediator mediator)
{
_logger = logger;
_mediator = mediator;
}

public async Task IndexAsync()
{
// send request, and show Response
var response = await _mediator.Send(new RequestModel());
Debug.WriteLine("Got response in controller: " +response);

return View();

}
3.2.4. 输出
Got response in controller: Pong 5/28/2021 2:04:26 PM
4. 总结
MediatR是一种进程内消息传递机制。
支持以同步或异步的形式进行请求/响应,命令,查询(CQRS),通知和事件的消息传递,并通过C#泛型支持消息的智能调度。
其核心是消息的解耦。
应用场景: 实现CQRS、EventBus等。
5. 参考 & 代码
参考: https://github.com/jbogard/MediatR
代码: https://github.com/jackniu81/dotnet/tree/main/MediatR-Demo

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
14
获赞与收藏
47

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

举报

0/150
提交
取消