如何从net Core中的异常中获取行号和文件名?

时间:2016-09-28 21:17:38

标签: c# asp.net-core

我曾经能够使用以下

来提取我的行号和类以获取异常
   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应用程序以与传统框架不同的方式访问这些服务,并且与应用于系统的安全策略相冲突。我已联系我们的微软代表,寻求更多信息,看看问题是否无法解决。将继续更新。

1 个答案:

答案 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();
    }
}