40

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ステータスコードで応答を返す代わりに、リクエストが例外をスローするのはなぜですか?

4

2 に答える 2

71

Webページがステータスコードを多用し、すべてがエラーであるとは限らない場合、これは非常に煩わしい場合があります。これは体の処理をかなり苦痛にする可能性があります。個人的には、この拡張メソッドを使用して応答を取得します。

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;
        }
    }
}
于 2012-04-10T04:26:20.513 に答える
1

なぜだめですか?これらは両方とも有効な設計オプションであり、HttpWebRequestはこのように機能するように設計されています。

于 2012-04-10T00:57:22.970 に答える