IT俱乐部 ASP.NET .NET 8 中如何利用 MediatR 实现高效消息传递

.NET 8 中如何利用 MediatR 实现高效消息传递

前言

MediatR 是 .NET 下的一个实现消息传递的库,轻量级、简洁高效,用于实现进程内的消息传递机制。它基于中介者设计模式,支持请求/响应、命令、查询、通知和事件等多种消息传递模式。通过泛型支持,MediatR 可以智能地调度不同类型的消息,非常适合用于领域事件处理。

在本文中,将通过一个简单的示例来介绍如何使用 MediatR 库在 .NET 8 项目中处理命令。我们将定义一个命令、一个处理器以及一个用于发送命令的服务,演示如何发送一个命令并处理它。

准备工作

1、创建项目

创建一个新的 .NET 8 WebAPI 标准项目,选择启用 OpenAPI 支持和使用控制器;

dotnet new webapi -n ManageCore.MediatrDemo 
cd ManageCore.MediatrDemo

2、添加 MediatR 包

使用以下命令添加 MediatR 包到项目中。

dotnet add package MediatR

实现示例

1、注册 MediatR

在 Program.cs 文件中,我们需要注册 MediatR 服务。

// Add services to the container.  
builder.Services.AddMediatR(mr =>{
   mr.RegisterServicesFromAssembly(typeof(Program).Assembly);
});

2、创建通知类

在项目中定义了一个简单的通知类 InfoDemo,它是 INotification 接口的实现。

using MediatR;
namespace ManageCore.MediatrDemo
{
    public record InfoDemo(string Msg) : INotification;
}

首先声明了一个名为 InfoDemo 的记录类型(record type)。

记录类型是一种特殊的类,主要用于表示不可变的数据类型,并提供了默认的实现来简化对象的创建和比较。

  • public record InfoDemo(string Msg):这里定义了一个名为 InfoDemo 的记录类型,它接受一个字符串类型的构造函数参数 Msg。这个参数将会成为 InfoDemo 类的一个只读属性。
  • : INotification:这里指定了 InfoDemo 类实现了 INotification 接口。在 MediatR 中,INotification 接口用于标记一个类型作为通知(Notification)处理,这意味着这个类型将用于发送通知而不需要等待响应。

注意:这段代码定义了一个名为 InfoDemo 的通知类,它包含一个只读属性 Msg,用于携带消息文本。这个类可以被用来发送通知,而不期待任何响应或结果。在实际应用中,你可能会使用 MediatR 的IMediator 接口来发送这种通知,并由其他组件来处理这些通知。

3、创建处理器类

创建一个通知处理器类 InfoDemoHandler ,用于处理通知并返回响应。

它是 INotificationHandler 接口的实现。

它接受一个 ILogger 类型的构造函数参数 _logger,并实现了 INotificationHandler 接口。INotificationHandler 接口是 MediatR 提供的接口,用于处理 T 类型的通知。

using MediatR;
namespace ManageCore.MediatrDemo
{
    /// 
    /// 通知处理器类
    /// 
    /// 
    public class InfoDemoHandler(ILogger _logger) : INotificationHandler
    {
        /// 
        /// 
        /// 
        /// 
        /// 
        /// 
        public Task Handle(InfoDemo notification, CancellationToken cancellationToken)
        {
            _logger.LogInformation($"InfoDemoHandler Received: {notification}. {DateTimeOffset.Now}");
            return Task.CompletedTask;
        }
    }
}

这段代码实现了 INotificationHandler 接口,并在 Handle 方法中处理 InfoDemo 类型的通知。

当 MediatR 接收到 InfoDemo 类型的通知时,它会调用 InfoDemoHandler 的 Handle 方法来处理该通知。

4、创建控制器类

定义一个名为 MediatorDemoController 的 ASP.NET Core 控制器,使用 MediatR 发布通知。

using MediatR;
using Microsoft.AspNetCore.Mvc;
namespace ManageCore.MediatrDemo.Controllers
{
    [ApiController]
    [Route("[controller]")]
    public class MediatorDemoController : ControllerBase
    {
        private readonly IMediator mediator;
        private readonly ILogger _logger;
        /// 
        ///初始化
        /// 
        /// 
        /// 
        public MediatorDemoController(IMediator mediator, ILogger logger)
        {
            this.mediator = mediator;
            _logger = logger;
        }
        /// 
        /// MediatorDemo 方法
        /// 
        /// 
        [HttpGet(Name = "MediatorDemoMethod")]
        public string MediatorDemoMethod()
        {
            var information = new InfoDemo("Mediator 控制器消息 ");
            mediator.Publish(information);
            _logger.LogInformation($"{DateTimeOffset.Now} : MediatorDemoController Send: {information}.");
            return $"Ok";
        }
    }
}

说明:这段代码定义了一个名为MediatorDemoController 的控制器类,它使用 MediatR 发布了一个名为InfoDemo的通知。当调用MediatorDemoMethod方法时,它会创建一个InfoDemo类型的通知实例,通过mediator发布该通知,并记录一条日志。

运行示例

1、启动 ASP.NET Core 应用程序

启动应用程序后MediatorDemoController控制器将被注册,并且构造函数将被调用来注入IMediatorILogger依赖项。

2、访问控制器方法

通过访问 /MediatorDemo的 GET 请求来调用MediatorDemoMethod方法。

3、创建并发布通知

MediatorDemoMethod 方法中,创建一个InfoDemo 类型的通知实例,并通过mediator.Publish(information) 发布该通知。

4、处理通知

当通知被发布时,所有实现了INotificationHandler接口的处理器都会被调用来处理通知。

InfoDemoHandler 处理器会接收到通知,并通过日志记录器记录一条日志,显示接收到的通知及其时间戳。

5、记录日志

在控制器中,通过_logger.LogInformation记录一条日志,显示发送的通知及其时间戳。

6、返回响应

控制器方法返回"Ok"字符串,表示执行成功。

7、预期结果

总结

通过这个简单的示例,可以在 .NET 8 应用程序中使用 MediatR 库来发布和处理通知,实现进程内的消息传递。这种方法有助于解耦组件,并使得应用程序更加模块化和可维护。示例不仅说明了如何使用MediatR 来处理通知,还说明了如何实现通知处理模式。通过定义通知和处理器,我们可以将应用程序的不同部分解耦,使得代码更加清晰和易于维护。

到此这篇关于.NET 8 中利用 MediatR 实现高效消息传递的文章就介绍到这了,更多相关.NET 8 MediatR消息传递内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部!

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/code/asp-net/13095.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部