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

Bas*_*yon 5 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();
Run Code Online (Sandbox Code Playgroud)

但是,现在每当我尝试提取该信息时,使用.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"

更新::

追求我能想到的每一个选项,我在不同的工作站上试过这个.它工作正常.显然它在我的工作站上的东西是失败的......所以问题是环境并不是特定于包装.当我弄清楚问题是什么时,我会再次更新.

所以经过进一步的调查有趣的话.虽然它是环境,但它也特定于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
Run Code Online (Sandbox Code Playgroud)

每当我尝试从网络核心应用程序运行它.似乎很清楚,Core应用程序以与传统框架不同的方式访问这些服务,并且与应用于系统的安全策略相冲突.我已联系我们的微软代表,寻求更多信息,看看问题是否无法解决.将继续更新.

Wil*_*Ray 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();
    }
}
Run Code Online (Sandbox Code Playgroud)