我尝试使用HttpWebRequest来验证URL的存在。我发现了几个基本上可以做到这一点的示例:
HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(Url);
request.Method = "HEAD";
using (HttpWebResponse response = request.GetResponse() as HttpWebResponse)
{
return response.StatusCode;
}
然而,如果url确实被破坏了,它就不会返回响应,而是抛出异常。
我将代码修改为:
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状态代码的响应?
3条答案
按热度按时间yhived7q1#
当网页大量使用状态码而不是所有的都是错误的时候,这会很烦人。这会让处理正文变得很痛苦。我个人使用这种扩展方法来获得响应。
jm2pwxwz2#
为什么不呢?它们都是有效的设计选项,而HttpWebRequest就是设计成这样工作的。
cbeh67ev3#
就像@Will一样,我编写了类似的扩展方法来从WebException中获取字符串形式的响应内容。
以上代码是未优化的解决方案。