我曾经能够使用以下
来提取我的行号和类以获取异常 System.Diagnostics.StackTrace trace = new System.Diagnostics.StackTrace(ex, true);
var stackFrame = trace.GetFrame(trace.FrameCount - 1);
var lineNumber = stackFrame.GetFileLineNumber();
var file = stackFrame.GetFileName();
然而,现在每当我尝试提取该信息时,使用.Net Core 1.0中的类库,行号始终为0,文件名始终为null。
我将needfileinfo布尔值设置为true,并且存在pdb文件。这个功能在.NET Core框架中是不起作用还是我现在应该采用一些不同的方法?
说到下面提供的答案。我已经在使用“System.Diagnostics.StackTrace”:“4.0.1”并且具有相同的结果。空FileName和0 FileNumber。我甚至开始了一个新项目,只复制他的代码和相同的结果。使用“System.Diagnostics.StackTrace”的空文件名和0文件号:“4.0.1”
UPDATE ::
追求我能想到的每一个选项我在不同的工作站上尝试过这个。它工作正常。显然它在我的工作站上的东西是失败的......所以问题是环境并不是特定于包装。当我弄清楚问题是什么时,我会再次更新。
所以经过进一步的调查后,有趣的是。虽然它是环境,但它也特定于Net Core。在同一环境中的非Net Core应用程序中,StackTrace工作正常。但是,我在事件日志中遇到安全审核失败
A privileged service was called.
Service:
Server: Security
Service Name: -
Process:
Process ID: 0x55a0
Process Name: C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\Remote Debugger\x64\msvsmon.exe
Service Request Information:
Privileges: SeCreateGlobalPrivilege
and
A privileged service was called.
Service:
Server: Security
Service Name: -
Process:
Process ID: 0x5628
Process Name: C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\CommonExtensions\Microsoft\IntelliTrace\14.0.0\IntelliTrace.exe
Service Request Information:
Privileges: SeCreateGlobalPrivilege
每当我尝试从网络核心应用程序运行它时。 似乎很清楚,Core应用程序以与传统框架不同的方式访问这些服务,并且与应用于系统的安全策略相冲突。我已联系我们的微软代表,寻求更多信息,看看问题是否无法解决。将继续更新。
答案 0 :(得分:6)
在我的"System.Diagnostics.StackTrace": "4.0.1"
文件中使用project.json
我能够使用以下代码正确获取错误的行号和文件名:
class Program
{
static void Main(string[] args)
{
var test = new Test();
try
{
test.TriggerError();
}
catch(Exception ex)
{
var trace = new StackTrace(ex, true);
var frame = trace.GetFrames().Last();
var lineNumber = frame.GetFileLineNumber();
var fileName = frame.GetFileName();
}
}
}
class Test
{
public void TriggerError()
{
throw new Exception();
}
}