await httpClient.SendAsync(httpContent) 是无响应的



await httpClient.SendAsync(httpContent)没有响应,尽管我在代码/url中没有发现错误,但它仍然挂起。请建议/帮助。

我的代码如下:

public async Task<string> Get_API_Result_String(string url, List<KeyValuePair<string, string>> parameters)
{
    string res = "";
    try
    {
        IsolatedStorageSettings settings = IsolatedStorageSettings.ApplicationSettings;
        //Prepare url
        Uri mainurl = new Uri(settings[FSAPARAM.UserSettingsParam.SERVERNAME].ToString());
        Uri requesturl = new Uri(mainurl, url);
        var httpClient = new HttpClient();
        var httpContent = new HttpRequestMessage(HttpMethod.Post, requesturl);
        // httpContent.Headers.ExpectContinue = false;
        httpContent.Content = new FormUrlEncodedContent(parameters);
        HttpResponseMessage response = await httpClient.SendAsync(httpContent);
        var result = await response.Content.ReadAsStringAsync();
        res = result.ToString();
        response.Dispose();
        httpClient.Dispose();
        httpContent.Dispose();
    }
    catch (Exception ex)
    {
        Logger l = new Logger();
        l.LogInfo("Get_API_Result_String: "+ url + ex.Message.ToString());
        ex = null;
        l = null;
    }
    return res;
}

在另一个类中调用它,如下所示:

NetUtil u = new NetUtil();
string result = await u.Get_API_Result_String(Register_API, values);
u = null;

我预测您的调用堆栈再往上,您正在返回的Task上调用WaitResult。这将导致僵局,我在博客上对此进行了充分解释。

总而言之,await将捕获上下文并使用它来恢复async方法;在 UI 应用程序上,这是一个 UI 线程。但是,如果 UI 线程被阻止(在对 WaitResult 的调用中),则该线程不可用于恢复 async 方法。

这对我有用:

httpClient.SendAsync(httpContent).ConfigureAwait(false);

我刚刚删除了await,只是按如下方式使用,它起作用了:

var result = httpClient.SendAsync(httpContent).Result;

但这不是一个好的做法。如尼古拉提到,我们不应该混合同步和异步调用。
我将调用方法更改为异步,问题已解决。

在我的身上没问题

  var response = httpClient.SendAsync(request);
  var responseResult = response.Result;
  if (responseResult.IsSuccessStatusCode)
  {
         var result = responseResult.Content.ReadAsStringAsync().Result;
         return result;
  }

返回压缩的 gzip 数据时刚刚遇到此错误。这是一种非常罕见的情况,因为 99% 次使用不同的输入数据一切都很好。不得不切换到HttpWebRequest。

最新更新