我正在与.Net的网络服务器进行通信。 Web服务器抛出500内部服务器错误并写入详细的错误消息。
我正在尝试读取从Web异常接收的错误消息,但是获取另一个Web异常。为什么抛出第二个WebException?
try
{
var webResponse = (HttpWebResponse)webRequest.GetResponse();
}
catch (WebException e)
{
if (e.Status == WebExceptionStatus.ProtocolError)
{
// the next line throws a web exception
Console.WriteLine(new StreamReader(e.Response.GetResponseStream()).ReadToEnd());
}
}
答案 0 :(得分:12)
为什么这令人惊讶?从MSDN中尝试以下内容:
try {
// Create a web request for an invalid site. Substitute the "invalid site" strong in the Create call with a invalid name.
HttpWebRequest myHttpWebRequest = (HttpWebRequest) WebRequest.Create("invalid site");
// Get the associated response for the above request.
using (HttpWebResponse myHttpWebResponse =
(HttpWebResponse) myHttpWebRequest.GetResponse()) {
myHttpWebResponse.Close();
}
}
catch(WebException e) {
Console.WriteLine("This program is expected to throw WebException on successful run."+
"\n\nException Message :" + e.Message);
if(e.Status == WebExceptionStatus.ProtocolError) {
var response = ((HttpWebResponse)e.Response);
Console.WriteLine("Status Code : {0}", response.StatusCode);
Console.WriteLine("Status Description : {0}", response.StatusDescription);
try {
using (var stream = response.GetResponseStream()) {
using (var reader = new StreamReader(stream)) {
var text = reader.ReadToEnd();
Console.WriteLine(text);
}
}
} catch (WebException ex) {
// Oh, well, we tried
}
}
}
catch(Exception e) {
Console.WriteLine(e.Message);
}