我正在尝试使用HttpWebRequest来验证是否存在Url。我找到了几个基本上做的例子:
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(Url);
request.Method = "HEAD";
using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
{
return response.StatusCode;
}
但是,如果网址确实被破坏了,它就不会返回响应,而是会抛出异常。
我将代码修改为:
try
{
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(Url);
request.Method = "HEAD";
using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
{
return response.StatusCode;
}
}
catch (System.Net.WebException ex)
{
var response = ex.Response as HttpWebResponse;
return response == null ? HttpStatusCode.InternalServerError : response.StatusCode;
}
似乎终于做了我想做的事。
但我想知道,为什么请求抛出异常而不是使用NotFound状态代码返回响应?
答案 0 :(得分:61)
当网页大量使用状态代码并且并非所有网页代码都是错误时,这可能会非常烦人。这可以使身体处理相当痛苦。我个人使用这种扩展方法来获得响应。
public static class HttpWebResponseExt
{
public static HttpWebResponse GetResponseNoException(this HttpWebRequest req)
{
try
{
return (HttpWebResponse)req.GetResponse();
}
catch (WebException we)
{
var resp = we.Response as HttpWebResponse;
if (resp == null)
throw;
return resp;
}
}
}
答案 1 :(得分:2)
为什么不呢?它们都是有效的设计选项,而HttpWebRequest只是设计用于这种方式。