这是我尝试制作一个对象转储程序:
using System;
using System.Collections.Generic;
using System.Reflection;
using System.Text;
namespace Inspector
{
public static class Inspector
{
public static string Inspect(this object o)
{
StringBuilder sb = new StringBuilder();
InspectObject(o, sb);
return sb.ToString();
}
private static void InspectObject(object o, StringBuilder sb)
{
Type objType = o.GetType();
if (objType == typeof(string))
sb.Append(o.ToString());
else
{
try
{
IList<PropertyInfo> props = new List<PropertyInfo>(objType.GetProperties());
foreach (PropertyInfo prop in props)
{
object propValue = null;
ParameterInfo[] ip = prop.GetIndexParameters();
if (ip.Length == 0)
{
propValue = prop.GetValue(o, null);
InspectObject(propValue, sb);
}
else
{
}
}
}
catch (Exception ex)
{
sb.Append(string.Format("Exception: {0}", ex.Message));
}
}
}
}
}
当我在HomeController的Index方法中使用它来检查Request
(Request.Inspect()
)时,w3wp.exe进程崩溃并且try-catch块没有执行此操作&#39的工作。
实际发生了什么?微软表示,只有未处理的异常会导致w3wp.exe崩溃,但我正在调用Request.Inspect()
包装到父try-catch块中;
答案 0 :(得分:1)
我不确定你使用的chrome.extension.getBackgroundPage()
的确切类型,所以我只读了HttpRequest类的文档。如果那不是你正在使用的,至少我可以让你知道发生了什么:
Request
类有一个名为HttpRequest
的{{1}}类型的属性,因此您为该属性调用RequestContext
RequestContext
的属性InspectObject
类型为RequestContext
,因此您为该属性调用HttpContext
HttpContextBase
有一个名为InspectObject
的{{1}}类型的属性,它是当前请求,而 - 是 - 您调用HttpContextBase
该属性,从1.开始,因为它是同一个实例 所以这个递归永远不会停止,你填满你的调用堆栈,直到你得到Request
。这种异常无法在HttpRequest
块中处理,因为堆栈(以及整个过程)已经损坏。
要解决此问题,您需要某种递归检测,告诉您是否尝试检查已检查过的对象。然后你可以在那一点停止递归 另外,您可以在一定深度停止递归。具体的解决方案取决于您需要的所有信息。