2009-06-12 3 views
2

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

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

ответ

0

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

1

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

+0

Я хотел, чтобы захватить его без специализированного инструмента. – ProfK

1

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

Exception для 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/