powered by simpleCommunicator - 2.0.56     © 2025 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
6 сообщений из 6, страница 1 из 1
HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
    #38283967
Фотография Strassebahn
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Иногда подвисает HttpWebRequest не смотря на заданый таймаут в 30 000 милисекунд.
В програме этот метод вызывается из гланого (GUI) потока (не надо плеваться. сам знаю),
когда запрос зависает спасает только диспетчер задач

Кто может подсказать почему запрос иногда зависает и как это можно обойти?

спасибо

код приведён ниже


Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
public string Http_Get(Http_Args args)
        {
            Uri uri = new Uri(args.url);
            string responce = "";
            HttpWebRequest webRequest = (HttpWebRequest)WebRequest.Create(uri);
            webRequest.Timeout = 30000;
            webRequest.ContentType = "application/x-www-form-urlencoded";
            webRequest.Method = "GET";
            webRequest.AutomaticDecompression = DecompressionMethods.Deflate | DecompressionMethods.GZip;
            webRequest.AllowAutoRedirect = args.redirect;
            webRequest.KeepAlive = args.keep_alive;
            webRequest.Headers.Add("Cookie:" + args.cookie_in);

            if (string.IsNullOrEmpty(args.user_agent))
            {
                webRequest.UserAgent = "Mozilla/4.0(compatible;MSIE 7.0;Windows NT 6.0; SLCC1;.NET CLR 2.0.50727;Media Center PC 5.0; .NET CLR 3.0.04506;.NET CLR 1.1.4322)";
            }
            else
            {
                webRequest.UserAgent = args.user_agent;
            }

            if (string.IsNullOrEmpty(args.accept))
            {
                webRequest.Accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-ms-application, application/vnd.ms-xpsdocument, application/xaml+xml, application/x-ms-xbap, application/x-shockwave-flash, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, app";
            }
            else
            {
                webRequest.Accept = args.accept;
            }

            if (string.IsNullOrEmpty(args.referer))
            {
            }
            else
            {
                webRequest.Referer = args.referer;
            }

            if (!string.IsNullOrEmpty(args.content_type))
            {
                webRequest.ContentType = args.content_type;
            }
            
            if (!string.IsNullOrEmpty(args.miscelaneous))
            {
                webRequest.Headers.Add("Miscellaneous", args.miscelaneous);
            }

            webRequest.Headers.Add("Accept-Language",  "en-us");

            using (WebResponse webResponse = webRequest.GetResponse())
            {
                if (webResponse == null)
                {
                    args.cookie_out = null;
                    return null;
                }
                using (StreamReader sr = new StreamReader(webResponse.GetResponseStream()))
                {

                    responce = sr.ReadToEnd().Trim();
                    sr.Close();
                    args.headers = webResponse.Headers;
                    if (webResponse.Headers.Get("Set-Cookie") != null)
                    {
                        args.cookie_out = webResponse.Headers.Get("Set-Cookie").Split(',');
                    }
                    else
                    {
                        args.cookie_out = new string[0];
                    }
                    args.all_cookies = new string[webResponse.Headers.Count];
                    for (int i = 0; i < webResponse.Headers.Count; i++)
                    {
                        args.all_cookies[i] = webResponse.Headers.AllKeys[i] + ":" + webResponse.Headers[i].ToString();
                    }

                }
            }
            return responce;
        }
...
Рейтинг: 0 / 0
HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
    #38284130
bazile
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Strassebahn, есть ли в сети прокси? Может он как-то придерживает твои соединения так что код считает, что таймаут не достигнут. Ради эксперимента можно ReadWriteTimeout уменьшить, но по логике общий таймаут в 30 секунд все равно принимается во внимание методами GetResponse/GetReponseStream. Еще я бы попробовал KeepAlive=false чтобы сервер сам закрыл соединение после отправки всех данных. Все равно код запрашивает только один ресурс так что KeepAlive=true никакой пользы не несет.

В коде есть пара непонятных мне моментов, которые не относятся к описаннй проблеме, но тем не менее.

- ContentType = "application/x-www-form-urlencoded" используется только для post запросов.

- Ты выставляешь Accept заголовок где есть двоичные файлы, но код может обработать только текстовые файлы. Я бы вообще убрал инциализацию по умолчанию для Accept.

- Для работы с Cookie есть специальный класс CookieContainer.
...
Рейтинг: 0 / 0
HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
    #38284171
Фотография Strassebahn
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Прокси нет.
Зависает только при определюнном аддресе (раз из 10)

Никогда не пользовался CookieContainer :)
...
Рейтинг: 0 / 0
HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
    #38284195
bazile
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
StrassebahnЗависает только при определюнном аддресе (раз из 10)
Устрой для этого адреса стресс-тест с паралельно запущеным Fiddler или сетевым анализатором чтобы понять на какой фазе обмена происходит подвисание.

StrassebahnНикогда не пользовался CookieContainer
Пора начинать значит.
...
Рейтинг: 0 / 0
HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
    #38284201
Фотография Strassebahn
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
авторУстрой для этого адреса стресс-тест с паралельно запущеным Fiddler или сетевым анализатором чтобы понять на какой фазе обмена происходит подвисание.

Зависание происходит на

Код: c#
1.
 using (WebResponse webResponse = webRequest.GetResponse())



Конечто я использую Fiddler :)
...
Рейтинг: 0 / 0
HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
    #38284246
Фотография Strassebahn
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Подправил код, буду тестировать день/два

висло в методе HTTP_POST, там исходящий поток не закрывался коректно
...
Рейтинг: 0 / 0
6 сообщений из 6, страница 1 из 1
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / HttpWebRequest Зависает надолго, несмотря на указаный TimeOut
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]