Эти решения довольно хороши, но они забывают, что могут быть другие коды состояния, кроме 200 ОК. Это решение, которое я использовал в производственных средах для мониторинга состояния и тому подобное.
Если на целевой странице имеется перенаправление URL или какое-либо другое условие, возвращаемое значение будет истинным с использованием этого метода. Кроме того, GetResponse () сгенерирует исключение и, следовательно, вы не получите StatusCode для него. Вам нужно перехватить исключение и проверить наличие ProtocolError.
Любой код состояния 400 или 500 вернет false. Все остальные возвращают истину.
Этот код легко модифицируется в соответствии с вашими потребностями для конкретных кодов состояния.
/// <summary>
/// This method will check a url to see that it does not return server or protocol errors
/// </summary>
/// <param name="url">The path to check</param>
/// <returns></returns>
public bool UrlIsValid(string url)
{
try
{
HttpWebRequest request = HttpWebRequest.Create(url) as HttpWebRequest;
request.Timeout = 5000; //set the timeout to 5 seconds to keep the user from waiting too long for the page to load
request.Method = "HEAD"; //Get only the header information -- no need to download any content
using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
{
int statusCode = (int)response.StatusCode;
if (statusCode >= 100 && statusCode < 400) //Good requests
{
return true;
}
else if (statusCode >= 500 && statusCode <= 510) //Server Errors
{
//log.Warn(String.Format("The remote server has thrown an internal error. Url is not valid: {0}", url));
Debug.WriteLine(String.Format("The remote server has thrown an internal error. Url is not valid: {0}", url));
return false;
}
}
}
catch (WebException ex)
{
if (ex.Status == WebExceptionStatus.ProtocolError) //400 errors
{
return false;
}
else
{
log.Warn(String.Format("Unhandled status [{0}] returned for url: {1}", ex.Status, url), ex);
}
}
catch (Exception ex)
{
log.Error(String.Format("Could not test url {0}.", url), ex);
}
return false;
}