4

我们的 MVC 应用程序使用 HttpClient 调用 WebAPI 操作。我决定使用 StructureMap 注入 HttpClient 并在控制器中覆盖 dispose

public HomeController(HttpClient httpClient)
{
    _httpClient = httpClient;
}

protected override void Dispose(bool disposing)
{
   if (disposing && _httpClient != null)
   {
       _httpClient.Dispose();
   }
   base.Dispose(disposing);
}

StructureMap ObjectInitialize 基本上看起来像这样..

x.For<HttpClient>().Use(() => new HttpClient() { BaseAddress = "my/uri/"});

当我构建它时,CodeAnalysis 会抱怨"Dispose objects before losing scope"并指向 IoC 代码。

我可以抑制它吗,或者我需要在哪里处理 HttpClient?我也试过

protected void Application_EndRequest(object sender, EventArgs e)
{
    ObjectFactory.ReleaseAndDisposeAllHttpScopedObjects();
}

但是我仍然违反了规则。

4

2 回答 2

6

处理 HttpClient 会清除所有活动的取消令牌和任何部分完成的请求/响应。在大多数正常情况下,处理它不是必需的,尽管按照惯例你应该这样做。请注意,虽然处理 HttpClient 将强制关闭 TCP 连接。

如果您的 MVC 应用程序对同一服务器进行大量调用,则可能值得跨请求保留 HttpClient 实例并重用它。这将避免您每次都必须重新设置默认请求标头,并且允许重用 TCP 连接。

于 2013-05-04T00:14:25.980 回答
3

触发对象创建的对象通常也是负责处理它的对象。在这种情况下,HttpClient 是由 Structuremap 通过DependencyResolveror创建的ControllerFactory。使用 Structuremap 处理瞬态对象没有简单的方法,因此您希望尽量减少IDisposable对象的注入,尤其是瞬态对象。我认为您应该将创建和处置放在服务中,然后将其注入控制器。

ReleaseAndDisposeAllHttpScopedObjects在这种情况下将不起作用,因为它只处理配置为HttpScoped的对象,即在整个 http 请求期间保留的对象。

于 2013-05-04T07:15:43.177 回答