2009-06-12 11 views
2

Ich habe eine Bibliothek Assembly, die Trace-Informationen ausgibt, und eine Winforms-Clientanwendung, die einen Trace-Listener über app.config hinzufügt. Wenn ich die Bibliothek in ASP.NET verwenden möchte, die nicht für die System.Diagnostics-Ablaufverfolgung konfiguriert ist, wie kann ich die Ablaufverfolgungsausgabe "abfangen"?Trace-Listener in ASP.NET

Bonus Frage: Kann ich etwas mit Elmah tun, um diese Informationen zu erfassen und zu protokollieren? Unsere ASP.NET-App verwendet derzeit Elmah zur Fehlerprotokollierung, aber das ist alles, was ich auf dieser Seite der Dinge weiß.

Antwort

0

Schreibcode für eine Trace-Datei Zuhörer programtically Anbringen und ermöglichen in web.config Tracing - Sie danach

1

Ich denke, dass, solange die Bibliothek Trace-Informationen ausgibt, diese Informationen mit jedem spezialisierten Tool (wie DebugView) oder sogar einem hausgewachsenen Tool erfasst werden können, unabhängig von der ASP.NET-Konfiguration.

+0

Ich will es ohne Spezialwerkzeug zu erfassen. – ProfK

1

getan werden, werde ich sehen, das alt ist und beantwortet, aber .. Ich habe genau das gleiche Problem hatte und ich kam mit

Exception-Klasse bis zur 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) { } 
    } 
} 

Der Zuhörer

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) 
     { 
     } 
    } 
} 

Und der GO-Code (Sie Ihre web.config verwenden können)

Tracer.Register(); 

bei http://truenorthit.co.uk/2015/04/17/trace-listener-for-elmah-asp-mvc-exception-logger/ gebloggt

Verwandte Themen