System.Net.WebException в консольном приложении - PullRequest
0 голосов
/ 06 января 2012

Я написал простое консольное приложение, чтобы проверить и проверить, работает ли мой сайт, проверив ссылку, которая всегда работает. Проблема была в том, что он вышел на днях и не уведомил меня, у него была ошибка:

system.net.webexception, время операции истекло system.net.httpwebrequest.getresponse

Я установил таймаут как 15000 миллисекунд, то есть 15 секунд. Я смотрю на firebug, когда он запрашивал, и он сказал, что запрос был прерван, я не смог увидеть код состояния. Но мне интересно, почему я получаю это ожидание, когда устанавливаю тайм-аут?

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net.Mail;
using System.Net;


namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            WebRequest request = WebRequest.Create("http://MYSITE.com/A/P/LIB/22?encoding=UTF-8&b=100");
            request.Timeout = 15000;
            SmtpClient mailserver = null;
            try
            {
                HttpWebResponse response = (HttpWebResponse)request.GetResponse();
                if (response == null || response.StatusCode != HttpStatusCode.OK)
                {
                    MailMessage contactMsg = new MailMessage();
                    contactMsg.To.Add(new MailAddress("abc123@mysite.com"));
                    contactMsg.From = new MailAddress("donotreply@mysite.com");
                    contactMsg.Subject = "Site is not responding!";
                    contactMsg.IsBodyHtml = true;
                    contactMsg.Body = "<html><body><h1>The Site is not responding</h1> " +
                        "Please check the server. <br /><br />Thank You</body></html>";
                    mailserver = new SmtpClient("smtp.mysite.com", 25);
                    //Setup email message
                    try
                    {
                        mailserver.Send(contactMsg);
                        mailserver.Dispose();
                    }
                    catch (Exception exc)
                    {
                        Console.WriteLine(exc.ToString());
                        mailserver.Dispose();
                    }
                    Console.WriteLine("Site is Down!");
                }
                else
                {
                    Console.WriteLine("Site is Up!");
                }
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.ToString());
                mailserver.Dispose();
            }
        }
    }
}

1 Ответ

1 голос
/ 06 января 2012

Ваш сайт не отвечает в течение 15 секунд, поэтому выдается исключение WebException. Timeout предназначен для исключения.

Свойство Timeout указывает продолжительность времени в миллисекундах, пока не истечет время ожидания запроса и не выдаст исключение WebException. Тайм-аут свойство влияет только на синхронные запросы, сделанные с помощью GetResponse метод. Для тайм-аута асинхронных запросов используйте метод Abort.

( 1010 * MSDN *)

...