Прослушивание трассировки в ASP.NET - PullRequest
2 голосов
/ 12 июня 2009

У меня есть сборка библиотеки, которая выводит информацию трассировки, и клиентское приложение winforms, которое добавляет прослушиватель трассировки через app.config. Если бы я использовал библиотеку в ASP.NET, не настроенную для трассировки System.Diagnostics, как я мог бы «перехватить» вывод трассировки?

Бонусный вопрос: Могу ли я что-то сделать с Elmah , чтобы поймать и записать эту информацию? Наше приложение ASP.NET в настоящее время использует Elmah для регистрации ошибок, но это все, что я знаю по этому поводу.

Ответы [ 3 ]

1 голос
/ 17 апреля 2015

Я вижу, что это старый и ответил, но .. У меня только что была та же проблема, и я придумал

Класс исключения для tracelistener

namespace TrueNorth.Elmah.TraceListener
{
    internal class TraceInformation : Exception
    {
        internal TraceInformation(string message) : base(message){}
    }

    internal class TraceError: Exception
    {
        internal TraceError(string message) : base(message) { }
    }

    internal class TraceWarning : Exception
    {
        internal TraceWarning(string message) : base(message) { }
    }

    internal class TraceWrite : Exception
    {
        internal TraceWrite(string message) : base(message) { }
    }
}

Слушатель

namespace TrueNorth.Elmah.TraceListener
{
    internal class ElmahListener : System.Diagnostics.TraceListener
    {
        public override void TraceEvent(TraceEventCache eventCache, string source, TraceEventType eventType, int id, string format, params object[] args)
        {
            TraceEvent(eventCache, source, eventType, id, string.Format(format, args));
        }
        public override void TraceEvent(TraceEventCache eventCache, string source, TraceEventType eventType, int id, string message) //
        {
            Exception exception;
            switch (eventType)
            {
                case TraceEventType.Information:
                    exception = new TraceInformation(message);
                    break;
                case TraceEventType.Error:
                    exception = new TraceError(message);
                    break;
                case TraceEventType.Warning:
                    exception = new TraceWarning(message);
                    break;
                default:
                    exception = new TraceWrite(message);
                    break;
            }
            if (HttpContext.Current.Session == null)
            {
                ErrorLog.GetDefault(null).Log(new Error(exception));
            }
            else
            {
                ErrorSignal.FromCurrentContext().Raise(exception );
            }
        }
        public override void TraceTransfer(TraceEventCache eventCache, string source, int id, string message, Guid relatedActivityId)
        {
            base.TraceTransfer(eventCache, source, id, message, relatedActivityId);
        }
        public override void Write(string message)
        {
        }
        public override void WriteLine(string message)
        {
        }
    }
}

И, код GO (вы можете использовать ваш web.config)

Tracer.Register();

в блоге на http://truenorthit.co.uk/2015/04/17/trace-listener-for-elmah-asp-mvc-exception-logger/

1 голос
/ 12 июня 2009

Я думаю, что до тех пор, пока библиотека выводит информацию трассировки, эта информация может быть захвачена любым специализированным инструментом (например, DebugView ) или даже собственным инструментом, независимо от конфигурации ASP.NET.

0 голосов
/ 12 июля 2010

написать код для программного подключения прослушивателя файла трассировки и включить трассировку в web.config - после этого вы закончите

...