- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我只想装饰一个 MediatR 处理程序。我尝试使用 Behaviours,但 Behaviors 为每个实现 IRequestHandler<TRequest,TResponse>
的处理程序注入(inject)了装饰器。
public class ProcessFirstCommand : IRequest<bool>
{
public string Message { get; set; }
}
public class ProcessFirstCommandHandler : IRequestHandler<ProcessFirstCommand, bool>
{
public Task<bool> Handle(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("Inside Process First Command Handler");
return Task.FromResult(true);
}
}
public class Manager
{
private readonly IMediator _mediator;
public Manager(IMediator mediator)
{
_mediator = mediator;
}
public void Execute()
{
_mediator.Send(new ProcessFirstCommand());
}
}
//Registering in Autofac for IRequestHandler
public class Module : Autofac.Module
{
protected override void Load(ContainerBuilder builder)
{
builder.RegisterAssemblyTypes(ThisAssembly)
.AsClosedTypesOf(typeof(IRequestHandler<,>));
}
}
_mediator.Send(new ProcessFirstCommand());
public class ProcessFirstCommandHandlerDecorator<TRequest, TResponse> : IRequestHandler<ProcessFirstCommand, bool>
where TRequest : ProcessFirstCommand
{
private readonly IRequestHandler<ProcessFirstCommand, bool> _handler;
public ProcessFirstCommandHandlerDecorator(IRequestHandler<ProcessFirstCommand, bool> handler)
{
_handler = handler;
}
public Task<bool> Handle(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("Inside Process First Command Handler Decorator");
_handler.Handle(request, cancellationToken);
return Task.FromResult(true);
}
}
最佳答案
如果您要做的只是在调用处理程序之前运行一些东西,那么您可以利用 Behaviors 来实现这一点。我知道你说过你之前已经尝试过这个,但是,你可以创建一个通用的行为来运行 IRequestPreProcessor 的所有实现。
注意:以下过程也适用于在处理程序运行后实现某些内容,您只需将接口(interface)从 IRequestPreProcessor 更改为 IRequestPostProcessor
因此,如果您有命令处理程序:
public class ProcessFirstCommandHandler : IRequestHandler<ProcessFirstCommand, bool>
{
public Task<bool> Handle(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("Inside Process First Command Handler");
return Task.FromResult(true);
}
}
你可以实现 IRequestPreProcessor(你需要的装饰器),但一定要指定你希望它运行的命令
public class PreProcessFirstCommand : IRequestPreprocessor<ProcessFirstCommand>
{
public ProcessFirstCommandHandlerDecorator()
{
}
public Task Process(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("Inside Process First Command Handler Decorator");
}
}
这将由您的通用 PreProcessorBehaviour 激活,它将在每个 MediatR 请求上运行,但只会注入(inject) IRequestPreProcessor 的实现,这些实现使用通用类型或指定 TRequest 类型,就像我们上面的 PreProcessFirstCommand 类所做的那样:
public class RequestPreProcessValidationBehaviour<TRequest, TResponse> : IPipelineBehavior<TRequest, TResponse> where TRequest : IRequest<TResponse>
{
private readonly IEnumerable<IRequestPreProcessor<TRequest>> _preProcessors;
public RequestPreProcessValidationBehaviour(IEnumerable<IRequestPreProcessor<TRequest>> preProcessors)
{
_preProcessors = preProcessors;
}
public async Task<TResponse> Handle(TRequest request, CancellationToken cancellationToken, RequestHandlerDelegate<TResponse> next)
{
foreach (var processor in _preProcessors)
{
await processor.Process(request, cancellationToken).ConfigureAwait(false);
}
return await next().ConfigureAwait(false);
}
}
注意:这个解决方案唯一的小问题是,如果你使用 ASP .NET Core 的默认依赖注入(inject)器,它只会注入(inject)一个实现 IRequestPreProcessor 并指定类型的类。
public class ProcessFirstCommandHandler : IRequestHandler<ProcessFirstCommand, bool>
{
public Task<bool> Handle(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("I'm inside the handler");
return Task.FromResult(true);
}
}
预处理第一命令.cs
public class PreProcessFirstCommand : IRequestPreprocessor<ProcessFirstCommand>
{
public ProcessFirstCommandHandlerDecorator()
{
}
public Task Process(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("I ran before the handler");
}
}
另一个PreProcessFirstCommand.cs
public class AnotherPreProcessFirstCommand : IRequestPreprocessor<ProcessFirstCommand>
{
public ProcessFirstCommandHandlerDecorator()
{
}
public Task Process(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("I ran before the handler as well!");
}
}
通用预处理命令.cs
public class GenericPreProcessCommand<TRequest> : IRequestPreprocessor<TRequest>
{
public ProcessFirstCommandHandlerDecorator()
{
}
public Task Process(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("I'm generic!");
}
}
另一个通用PreProcessCommand.cs
public class AnotherGenericPreProcessCommand<TRequest> : IRequestPreprocessor<TRequest>
{
public ProcessFirstCommandHandlerDecorator()
{
}
public Task Process(ProcessFirstCommand request, CancellationToken cancellationToken)
{
Console.WriteLine("I'm generic aswell!");
}
}
使用前面提到的通用 PreProcessorBehavior,这将注入(inject) GenericPreProcessCommand 和 AnotherGenericPreProcessCommand,但只注入(inject) PreProcessFirstCommand 或 AnotherPreProcessFirstCommand 之一。这似乎只是 DI 的一个限制。我在
official github issue 上为 MediatR 的创建者 Jimmy Bogard 留下了评论。 ,所以请务必阅读并在那里做出贡献。
关于c# - 如何装饰 MediatR 处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54580769/
我已经使用 MediatR 尝试了 CQRS 模式,并且我喜欢应用程序正在转换的干净状态。 在我见过和使用过的所有例子中,我总是这样做 await Mediator.Send(command); 查询
我正在尝试在 .NET Framework 4.6.2 中使用 Autofac 运行 MediatR。 我的注册: public class MediatorModule : Autofac.Modu
有谁知道如何在控制台应用程序中实现 MediatR,以使用 _mediatr.Send(obj) 语法调用处理函数。我正在使用 .Net 6 框架。感谢您的帮助。 最佳答案 首先,您必须安装这些包:
如果我发送 HTTP Get 请求: /api/Company/1 我有一个 OwinMiddleware我在哪里使用 context确定path和 IAsyncRequest 的 json 内容.
我在应用程序中使用 MediatR 和 CQRS。以下两条语句存在于很多模块中,在应用程序中可能会被并发调用(这是一个blazor应用程序)。 await Mediator.Send(new AddI
如何设置 PipelineBehavior 的优先级?我有 3 个管道。我想先执行 AuthorizationPipeline。如果 AuthorizationPipeline 抛出任何 Securi
您好,我已经使用这种带有管道行为的 Mediator CQRS 模式有一段时间了,但现在我遇到了一个问题,即 TResponse 和 TRequest 的通用实现还不够。因此,我试图了解为两个非常具体
我正在使用 Mediatr 开发 ASP.NET Core 2.2 Web API 应用程序。 我有一个看起来像的处理程序 - public class MyQueryHandler : IReque
在查询中对当前用户建模的最佳方法是什么?我正在创建一个 Razor 页面应用程序。在执行查询和命令时,我需要能够附加当前用户。有推荐的方法吗? 最佳答案 下面的方法对我很有效,因为我让用户进入了我的
在 MediatR 的文档中说: Containers that support generic variance will dispatch accordingly. For example, yo
我正在使用 MediatR具有以下类: public class GetPostsRequest : IRequest> { public Int32 Age { get; set; } } pu
我在我的 web api 2 项目中使用 Mediatr 4。与 FluentValidation 和 Unity 一起,我一直在添加管道行为来验证我的请求。 public class Validat
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 3 年前。 Improve this qu
我是 MediatR 的新手,尝试使用管道行为进行请求验证,如果发生任何错误,我遇到的所有示例都会抛出 ValidationException。 下面的代码是验证管道的示例: public class
我意识到我看到了(非常相似的)问题,但这似乎与通常提出的问题略有不同。 我得到了这个通知/通知处理程序 public class GenericEvent : INotification {
我正在研究 CQRS 和 MediatR 库,试图学习一些最佳实践。我遇到的一个问题是命令/查询处理程序中的代码重复。我想知道在处理程序之间共享逻辑的最佳方式是什么。 例子:我有一个定义 ID 属性的
如何让我的 MediatR 通知处理程序触发并忘记? 我的示例代码: public class BackupDatabase : INotification {} public class Backu
我想缓存一些来自 CommandsHandlers 的响应。 我已经使用 IPipelineBehaviour 做到了这一点,但我的请求中只有 5% 确实必须有缓存,而其他 95% 必须跳过此管道。有
我只想装饰一个 MediatR 处理程序。我尝试使用 Behaviours,但 Behaviors 为每个实现 IRequestHandler 的处理程序注入(inject)了装饰器。 public
我尝试使用CQRS制作.NET Core API,但由于MediatR错误而无法构建它: System.AggregateException:'某些服务无法构造(验证服务描述符'ServiceType
我是一名优秀的程序员,十分优秀!