Почему HttpWebRequest сбоит в первый раз, а затем работает нормально? - PullRequest
0 голосов
/ 27 января 2011

Я стараюсь интегрировать fusemail в asp.net 2.0.Я использую HttpWebRequest для запроса страниц API.Недавно я обратил внимание на то, что HttpWebRequest завершается с ошибкой в ​​первый раз, а затем продолжается и последующие запросы выполняются успешно.

скажем (я знаю, что если я использую goto, это плохой подход к программированию), если я использую этот код

retry:
        try
        {
            Uri uri = new Uri("http://www.fusemail.com/api/request.html");
            if (uri.Scheme == Uri.UriSchemeHttp)
            {

                HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(uri);
                request.PreAuthenticate = true;
                request.Method =
                WebRequestMethods.Http.Post;

                //request.ReadWriteTimeout = System.Threading.Timeout.Infinite;
                //request.Timeout = System.Threading.Timeout.Infinite;
                request.ContentLength = data.Length;
                request.ContentType =
                "application/x-www-form-urlencoded";
                //request.UserAgent = Request.UserAgent;
                request.UserAgent = "Mozilla/4.0";
                request.KeepAlive = false;

                request.ServicePoint.Expect100Continue = true;
                //request.Accept = "Accept: text/html,application/xhtml+xml,application/xml";


                StreamWriter writer = new StreamWriter(request.GetRequestStream());
                writer.Write(data);
                writer.Close();

                HttpWebResponse response = (HttpWebResponse)request.GetResponse();

                StreamReader reader = new StreamReader(response.GetResponseStream());
                string tmp = reader.ReadToEnd();
                response.Close();
                //Response.Write(tmp);

                if (!String.IsNullOrEmpty(tmp))
                {
                    return tmp;
                }
            }
            return String.Empty;
        }
        catch (WebException ex)
        {

            goto retry;
        }

работает после сбоя один раз.Я пишу в текстовый файл в случае ошибки, и после неудачного запроса он работает во второй раз.Я использую ASP.Net 2.0, а веб-сайт размещен на IIS 7 с Windows Server 2008 Standard.Также проверяя адрес API, он завершается с ошибкой в ​​первый раз, а затем отвечает

C:\>ping 67.207.202.118

Pinging 67.207.202.118 with 32 bytes of data:
Reply from 192.168.0.253: **Destination host unreachable**.
Reply from 67.207.202.118: bytes=32 time=218ms TTL=49
Reply from 67.207.202.118: bytes=32 time=218ms TTL=49
Reply from 67.207.202.118: bytes=32 time=217ms TTL=49

Ping statistics for 67.207.202.118:
    Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
    Minimum = 217ms, Maximum = 218ms, Average = 217ms

При первом сбое в HttpWebRequest происходит сбой с этой ошибкой

System.Net.WebException: невозможно подключиться кудаленный сервер ---> System.Net.Sockets.SocketException: попытка подключения не удалась, потому что подключенная сторона не ответила должным образом через определенный промежуток времени, или не удалось установить соединение, так как подключенный хост не ответил 67.207.202.118:80

Есть ли проблема с аутентификацией в первый раз?Я читал на некоторых форумах, он сначала отправляет 401 Несанкционированный, а затем он может подключиться.Я не могу проверить это с помощью Fiddler.

Что-то не так с конфигурацией IIS?

1 Ответ

0 голосов
/ 17 апреля 2011

Это вообще не проблема программирования, я столкнулся с подобной проблемой позже, и это была проблема конфигурации сети из-за настроек ISA-сервера / брандмауэра.Вы должны обратиться к администратору сети, чтобы проверить эту проблему.

Хотелось бы, чтобы это помогло вам.

Ваш,

Мохамед Камаль Эльбеа

Старший.Разработчик

...