簡體   English   中英

System.Net.Http.HttpClient超時似乎被忽略

[英]System.Net.Http.HttpClient Timeout seems to be ignored

我正在使用Xamarin.iOS版本:8.10.5.26(獨立版),並且由於超時使用HttpClient()發送的請求而面臨一個非常奇怪的行為:

以下代碼嘗試從url獲取結果,並具有60秒的超時時間(1分鍾),但是當請求被激發時,它花費了大約90秒的超時時間。 撥打電話后,我手動關閉了網絡連接以檢查超時。 觀察到這花費了超過60秒。

public async Task<Dictionary<string,object>> GetPatientDataASync (string lUsername)
    {
        var lDict = new Dictionary<string,object> ();
        try {
            string lQuerystring = "{Email: '" + lUsername + "'}";
            String lUrl = String.Format (Constants.mURLPatient + "?where={0}", JObject.Parse (lQuerystring));
            var lClient = new HttpClient ();
            lClient.BaseAddress = new Uri (lUrl);
            lClient.DefaultRequestHeaders
                .Accept
                .Add (new MediaTypeWithQualityHeaderValue ("application/json"));
            lClient.DefaultRequestHeaders.Add ("X-Parse-Application-Id", Constants.mKeyParseAppId);
            lClient.DefaultRequestHeaders.Add ("X-Parse-REST-API-Key", Constants.mKeyRestAPIKey);
            lClient.Timeout = new TimeSpan (0, 1, 0);
            var request = new HttpRequestMessage ();
            request.Method = HttpMethod.Get;
            if (Utility.isNetworkConnected ()) {
                bool responseStatus = false;
                await lClient.SendAsync (request)
                    .ContinueWith (responseTask => {
                    if (responseTask != null) {
                        var response = responseTask.Result;
                        if (response != null) {
                        if (response.IsSuccessStatusCode) {
                                var responseContent = response.Content;
                                if (responseContent != null) {
                                    string responseString = responseContent.ReadAsStringAsync ().Result;
                                    if (!string.IsNullOrWhiteSpace (responseString)) {
                                        JObject json = JObject.Parse (responseString);
                                        if (json != null) {
                                            if (json ["results"].Any ()) {
                                                Patient user = Patient.Instance;
                                                user.objectId = json.SelectToken (@"results[0].objectId").Value<string> ();
                                                user.Email = json.SelectToken (@"results[0].Email").Value<string> ();
                                                user.Name = json.SelectToken (@"results[0].Name").Value<string> ();
                                                user.IsNotificationsEnabled = json.SelectToken (@"results[0].IsNotificationsEnabled").Value<string> ();

                                                Application.Current.Properties ["IsNotificationsEnabled"] = json.SelectToken (@"results[0].IsNotificationsEnabled").Value<string> ();

                                                if (json.SelectToken (@"results[0].DeviceToken") != null) {
                                                    var deviceToken = json.SelectToken (@"results[0].DeviceToken").Value<JArray> ();
                                                    if (deviceToken != null)
                                                        user.DeviceToken = deviceToken.ToObject < List<string>> ();
                                                } else {
                                                    user.DeviceToken = new List<string> ();
                                                }

                                                var doctors = json.SelectToken (@"results[0].MyDoctors").Value<JArray> ();
                                                user.AllergicTo = json.SelectToken (@"results[0].AllergicTo").Value<string> ();
                                                user.ContactNo = json.SelectToken (@"results[0].ContactNo").Value<string> ();
                                                user.BloodGroup = json.SelectToken (@"results[0].BloodGroup").Value<string> ();
                                                user.MyDoctors = doctors != null ? doctors.ToObject<List<string>> () : new List<string> ();
                                                responseStatus = true;
                                            } else
                                                responseStatus = false;
                                        }
                                    }
                                }
                            }
                        }
                    }
                });
              lDict.Add (SUCCESS_CODE, responseStatus);
                return lDict;
            } else {
                lDict.Add (NO_INTERNET, Constants.mStringNoInternetMessage);
                return lDict;
            }
        } catch (Exception e) {
            Debug.WriteLine (e.Message + "\n " + e.StackTrace);
            lDict.Add (EXCEPTION_OCCURED, e);
            return lDict;
        }
    }

如果我的代碼中有錯誤,請告訴我。 這里也報告了相同的問題:

  1. 第一個連結

  2. 第二連結

這是一個已知的錯誤,多年來已打開,關閉並重新打開了幾次。 它已經在這里這里報道

有解決方法:

  1. 定義CancellationTokenSource並將Token設置為http請求;
  2. 像這樣cts.CancelAfter(timeout);CancellationTokenSource上通過超時調用cancel cts.CancelAfter(timeout);
  3. 不要忘記捕獲異常,就像這樣。

try
{
}
catch(TaskCanceledException)
{
    if(!cts.Token.IsCancellationRequested)
    {// timeout
    }
    else
    {//other reason
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM