zoukankan      html  css  js  c++  java
  • 为重复使用的HttpClient对象动态修改Timeout

    最近博客园被**了, 赶紧水一文支持一下博客园,加油!

    问题现象

    HttpClient被使用过之后, 在修改它们的属性会抛出错误This instance has already started one or more requests. Properties can only be modified before sending the first request.

    场景

    • 单例 HttpClient 对象, 我们要修改它的 Timeout
    • Scope生命周期的 HttpClient, 我们要修改它的 Timeout

    解决方法一

    可以把 HttpClient 的生命周期改成 Transient, 并且每次要用的时候都从 IServiceProvider 获取.

    解决方法二

    • 在注册 HttpClient 的时候把它的 Timeout 修改为 System.Threading.Timeout.InfiniteTimeSpan
      services.AddHttpClient<MyApiService>((sp, client) =>
      {
          client.Timeout = System.Threading.Timeout.InfiniteTimeSpan;
          client.BaseAddress = sp.GetService<MyOptions>().ApiEndpoint;
          }
      });
      
    • 然后调用的地方使用自己的CancellationToken来实现即可, 其实HttpClient.Timeout在内部也是一样的方式.
      async Task<HttpResponseMessage> RequestAsync(HttpRequestMessage httpRequest, CancellationToken token, TimeSpan timeout)
      {
          using var cts = CancellationTokenSource.CreateLinkedTokenSource(token);
          cts.CancelAfter(timeout);
          return await this.httpClient.SendAsync(httpRequest, cts.Token);
      }
      

    参考HttpClient.SendAsync的部分源代码:

    CancellationTokenSource cts;
    bool disposeCts;
    bool hasTimeout = _timeout != s_infiniteTimeout;
    if (hasTimeout || cancellationToken.CanBeCanceled)
    {
        disposeCts = true;
        cts = CancellationTokenSource.CreateLinkedTokenSource(cancellationToken, _pendingRequestsCts.Token);
        if (hasTimeout)
        {
            cts.CancelAfter(_timeout);
        }
    }
    else
    {
        disposeCts = false;
        cts = _pendingRequestsCts;
    }
    
    
  • 相关阅读:
    UIlabel自适应高度和自动换行
    ios2048小游戏
    NSPredicate
    NSURLConnection同步与异步请求 问题
    视频播放器开发中遇到的一些小问题MPMoviePlayerController
    storyboard中xib文件不加载问题
    cell的imageVIew的fram问题
    NSArray和NSDictionary添加空对象,以及nil和Nil和NULL和NSNull
    xcode5 和code6中push后方法执行的先后问题
    UItableView自定义标题(headerView)重用问题
  • 原文地址:https://www.cnblogs.com/calvinK/p/14612084.html
Copyright © 2011-2022 走看看