首页 > 解决方案 > 带有 CancellationToke 的 AddScoped 依赖项

问题描述

我有一个针对每个 REST API 请求的 .NET 核心依赖项。它是Startup.ConfigureServices通过调用添加的AddScoped

我想为此添加取消支持。如果我将 a 添加CancellationToken cancellationToken到任何控制器操作的参数中,我可以获得一个令牌,如果客户端请求是,则该令牌会被取消。然后我可以将该令牌传递给我的依赖项上的所有方法。

但是,依赖项的范围仅限于请求,因此通过操作将令牌向下传递给方法感觉没有必要 - 我可以CancellationToken以某种方式将其添加到范围依赖项中吗?

标签: c#asp.net-core.net-coredependency-injectionrequest-cancelling

解决方案


我可以以某种方式将 CancellationToken 添加到作用域依赖项中吗?

嗯,技术上是的。即通过注入IHttpAccessor和访问HttpContext.RequestAborted属性,如果已定义,这与您通常传递给控制器​​操作的取消标记相同。

但是实际上不鼓励使用动作参数重载,因为在每个控制器动作中,您都可以通过HttpContext.RequestAborted它访问取消令牌,并且在控制器动作中使用它会使令牌公开,即在创建 Swagger 方案时(至少是 2017 年的情况),使用它HttpContext本身并没有将其暴露给公众。

唯一的例外似乎是,当使用不继承ControllerControllerBase不注入IHttpAccessor该控制器的“Poco 控制器”时。

IHttpAccessor但是将取消令牌注入任意服务是有问题的,因为您对 Web 框架 ( / HttpContext)有硬依赖。

最好和最干净CancellationToken的方法是在您的方法上保留一个可以以有意义的方式取消并使令牌可选的参数,因此您只能在您有请求或可以取消的情况下传递参数

public Task<Result> ProcessSomething(string param1, CancellationToken cancellationToken = default)
{
}

推荐阅读