當前位置: 首頁>>代碼示例>>C#>>正文


C# NLog.LogEventInfo類代碼示例

本文整理匯總了C#中NLog.LogEventInfo的典型用法代碼示例。如果您正苦於以下問題:C# LogEventInfo類的具體用法?C# LogEventInfo怎麽用?C# LogEventInfo使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


LogEventInfo類屬於NLog命名空間,在下文中一共展示了LogEventInfo類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Log

        public void Log(LogLevel level, string message, params object[] arguments)
        {
            var info = new LogEventInfo(GetLevel(level), Key, message);
            info.Parameters = arguments;

            LogManager.GetLogger(Key).Log(info);
        }
開發者ID:samuelabj,項目名稱:EpisodeTracker,代碼行數:7,代碼來源:Logger.cs

示例2: Write

        /// <summary>
        /// Format and output logvent
        /// </summary>
        /// <param name="logEvent">If caller is NLogConnector, <paramref name="logEvent"/></param>.properties will have a complete set of values of HashTag.Diagnostics.LogEvent
        protected override void Write(LogEventInfo logEvent)
        {
            var msg = new Dictionary<object, object>();
            if (logEvent.Exception != null)
            {
                msg["exception"] = logEvent.Exception;
            }

            if (logEvent.HasStackTrace && logEvent.StackTrace != null)
            {
                msg["stackTrace"] = logEvent.StackTrace;
            }

            if (logEvent.UserStackFrame != null)
            {
                msg["userStackFrame"] = logEvent.UserStackFrame;
                msg["userStackFrameIndex"] = logEvent.UserStackFrameNumber;
            }

            foreach(var prop in logEvent.Properties)
            {
                msg[prop.Key] = prop.Value;
            }

            var id = msg["UUID"].ToString();

            var s = JsonConvert.SerializeObject(msg,Formatting.Indented);
            string fileName = Path.Combine(dropFolder, id.ToString()) + ".log";
            File.WriteAllText(fileName, s);
        }
開發者ID:HashTagDotNet,項目名稱:EventLogger,代碼行數:34,代碼來源:NLogSplunkTarget.cs

示例3: Log

 public static void Log(string loggerName, LogLevel logLevel, string eventID, string message)
 {
     LogEventInfo logEvent = new LogEventInfo(logLevel, _logger.Name, message);
     logEvent.Properties["EventID"] = eventID;
     logEvent.Properties["LoggerName"] = loggerName;
     _logger.Log(typeof(EventLogger), logEvent);
 }
開發者ID:majilik,項目名稱:RecruitmentSystem,代碼行數:7,代碼來源:EventLogger.cs

示例4: CreateLogDocument

        /// <summary>
        /// The create log document.
        /// </summary>
        /// <param name="logEvent">
        /// The log event.
        /// </param>
        /// <returns>
        /// The <see cref="Document"/>.
        /// </returns>
        private Document CreateLogDocument(LogEventInfo logEvent)
        {
            var log = new Document();
            log["Id"] = logEvent.SequenceID;
            log["TimeStamp"] = logEvent.TimeStamp;
            log["Level"] = logEvent.Level.ToString();
            log["Message"] = logEvent.Message;
            log["UserStackFrameNumber"] = logEvent.UserStackFrameNumber;
            if (logEvent.UserStackFrame != null)
            {
                log["FileName"] = logEvent.UserStackFrame.GetFileName();
                log["FileLineNumber"] = logEvent.UserStackFrame.GetFileLineNumber();
                log["FileColumnNumber"] = logEvent.UserStackFrame.GetFileColumnNumber();
                log["MethodName"] = logEvent.UserStackFrame.GetMethod().Name;
            }

            if (logEvent.Exception != null)
            {
                log["ExceptionMessage"] = logEvent.Exception.Message;
                log["ExceptionHResult"] = logEvent.Exception.HResult;
                log["ExceptionStackTrace"] = logEvent.Exception.StackTrace;
                log["ExceptionSource"] = logEvent.Exception.Source;
            }

            log["UserEmail"] = logEvent.Properties["UserEmail"].ToString();
            log["OrderId"] = logEvent.Properties["OrderId"].ToString();
            log["PackageId"] = logEvent.Properties["PackageId"].ToString();
            log["TransactionId"] = logEvent.Properties["TransactionId"].ToString();

            return log;
        }
開發者ID:Naviam,項目名稱:Shop-Any-Ware,代碼行數:40,代碼來源:NLogAmazonDynamoDbTarget.cs

示例5: Check

 protected override FilterResult Check(LogEventInfo ev)
 {
     if (ev.TimeStamp.Hour >= FromHour && ev.TimeStamp.Hour <= ToHour)
         return Result;
     else
         return FilterResult.Neutral;
 }
開發者ID:CharlieBP,項目名稱:NLog,代碼行數:7,代碼來源:MyFirstFilter.cs

示例6: Test4

 public void Test4()
 {
     Layout l = new Layout("${rot13:${event-context:aaa}}");
     LogEventInfo lei = new LogEventInfo(LogLevel.Info, "aaa", "bbb");
     lei.Context["aaa"] = "HELLO";
     Assert.AreEqual("URYYB", l.GetFormattedMessage(lei));
 }
開發者ID:tdhieu,項目名稱:openvss,代碼行數:7,代碼來源:Rot13Tests.cs

示例7: Append

        /// <summary>
        /// Renders the specified environmental information and appends it to the specified <see cref="T:System.Text.StringBuilder"/>.
        /// </summary>
        /// <param name="builder">The <see cref="T:System.Text.StringBuilder"/> to append the rendered data to.</param><param name="logEvent">Logging event.</param>
        protected override void Append(StringBuilder builder, LogEventInfo logEvent)
        {
            try
            {
                if (HttpContext.Current == null)
                    return;

                var context = new HttpContextWrapper(HttpContext.Current);

                if (context.Request.RequestContext == null)
                    return;

                var work = context.Request.RequestContext.GetWorkContext();
                if (work == null)
                    return;

                ShellSettings settings;
                if (!work.TryResolve(out settings))
                    return;

                builder.Append("Tenant:");
                builder.AppendLine(settings.Name);
            }
            catch
            {
            }
        }
開發者ID:l1183479157,項目名稱:RabbitHub,代碼行數:31,代碼來源:TenantLayoutRenderer.cs

示例8: Append

        protected override void Append(StringBuilder builder, LogEventInfo logEvent)
        {
            var record =  logEvent.Properties[NLogTraceWriter.RecordKey] as TraceRecord;

            if (record != null)
            {
                if (Operation)
                    builder.Append(record.Operation);

                if (Status)
                    builder.Append(record.Status.ToString());

                if (StatusCode)
                    builder.Append(Convert.ToInt32(record.Status));

                if (RequestId)
                    builder.Append(record.RequestId);

                if (Operator)
                    builder.Append(record.Operator);

                if (Kind)
                    builder.Append(record.Kind.ToString());

                if (AcceptType)
                    builder.Append(record.Request.Headers.Accept.ToString());

                if (Host)
                    builder.Append(record.Request.Headers.Host);
            }
        }
開發者ID:kfrancis,項目名稱:webapi.nlog,代碼行數:31,代碼來源:WebApiTraceRenderer.cs

示例9: Write

 protected override void Write(LogEventInfo logEvent)
 {
     if (logEvent.Level >= LogLevel.Warn)
     {
         _logs.Add(logEvent);
     }
 }
開發者ID:keep3r,項目名稱:Sonarr,代碼行數:7,代碼來源:ExceptionVerification.cs

示例10: Append

        protected override void Append( StringBuilder builder, LogEventInfo logEvent )
        {
            object value;
            if (!logEvent.Properties.TryGetValue( NLogTraceWriter.RecordKey, out value ))
                return;

            var record = value as TraceRecord;
            if (record == null)
                return;


            if (Operation)
                builder.Append( record.Operation );

            if (Status)
                builder.Append( record.Status.ToString() );

            if (StatusCode)
                builder.Append( Convert.ToInt32( record.Status ) );

            if (RequestId)
                builder.Append( record.RequestId );

            if (Operator)
                builder.Append( record.Operator );

            if (Kind)
                builder.Append( record.Kind.ToString() );

        }
開發者ID:mpaschetto,項目名稱:webapi.nlog,代碼行數:30,代碼來源:WebApiTraceRenderer.cs

示例11: Write

    protected override void Write(LogEventInfo logEvent)
    {
      try
      {
        string message = Layout.Render(logEvent);

        // echo to debug
        Debug.WriteLine(message);

        ScriptObject scriptMethod = null;

        if (logEvent.Level == LogLevel.Info)
          scriptMethod = _debugInfo;
        else if (logEvent.Level == LogLevel.Warn)
          scriptMethod = _debugWarn;
        else if (logEvent.Level == LogLevel.Error)
          scriptMethod = _debugError;

        if (scriptMethod == null)
          scriptMethod = _debugLog;

        if (scriptMethod == null)
          return;

        // thread safe
        Deployment.Current.Dispatcher.BeginInvoke(() => 
          scriptMethod.InvokeSelf(message));
      }
      catch (Exception ex)
      {
        Debug.WriteLine("Error calling debug.log function: " + ex);
      }
    }
開發者ID:modulexcite,項目名稱:LoreSoft.Shared,代碼行數:33,代碼來源:BrowserConsoleTarget.cs

示例12: Write

        protected override void Write(LogEventInfo logEventInfo)
        {
            if (DocumentStore == null)
                DocumentStore = DependencyManager.GetInstance<IRavenDbContext>().DocumentStore;

            var logEvent = new LogEvent
            {
                FormattedMessage = logEventInfo.FormattedMessage,
                Level = logEventInfo.Level.Name,
                TimeStamp = logEventInfo.TimeStamp
            };
            // Set exceptions
            if (logEventInfo.Exception != null)
            {
                logEvent.Exception = logEventInfo.Exception.StackTrace;
                if (logEventInfo.Exception.InnerException != null)
                {
                    logEvent.InnerException = logEventInfo.Exception.InnerException.Message + "<br/>" + logEventInfo.Exception.InnerException.StackTrace;
                }
            }

            using (var session = DocumentStore.OpenSession())
            {
                session.Store(logEvent);
                session.SaveChanges();
            }
        }
開發者ID:jessetinell,項目名稱:imenyn.se,代碼行數:27,代碼來源:NLogRavenDbTarget.cs

示例13: Info

        public static LogEventInfo Info(string loggerName, string message)
        {
            LogEventInfo evt = new LogEventInfo(LogLevel.Info, loggerName, message);
            evt.Properties["message"] = message;

            return evt;
        }
開發者ID:dublow,項目名稱:MagicPlaylist,代碼行數:7,代碼來源:LoggerCreator.cs

示例14: MetricsCollector

        public MetricsCollector()
        {
            var config = ConfigurationManager.GetSection("CollectdWinConfig") as CollectdWinConfig;
            if (config == null)
            {
                LogEventInfo logEvent = new LogEventInfo(LogLevel.Error, Logger.Name, "Cannot get configuration section");
                logEvent.Properties.Add("EventID", ErrorCodes.ERROR_CONFIGURATION_EXCEPTION);
                Logger.Log(logEvent);
                return;
            }

            _runReadThread = false;
            _runWriteThread = false;

            var registry = new PluginRegistry();
            _plugins = registry.CreatePlugins();

            _interval = config.GeneralSettings.Interval;
            if (_interval <= 10)
                _interval = 10;

            _timeout = config.GeneralSettings.Timeout;
            if (_timeout <= _interval)
                _timeout = _interval*3;

            bool storeRates = config.GeneralSettings.StoreRates;

            _aggregator = new Aggregator(_timeout, storeRates);

            _collectedValueQueue = new Queue<CollectableValue>();
            _queueLock = new Object();
        }
開發者ID:Netuitive,項目名稱:collectdwin,代碼行數:32,代碼來源:MetricsCollector.cs

示例15: CreateToolWindow

        private Window CreateToolWindow(IDockableUserControl control)
        {
            object userControlObject = null;
            Window toolWindow;
            try
            {
                _logger.Trace("Loading \"{0}\" ClassId {1}", control.Caption, control.ClassId);
                toolWindow = _vbe.Windows.CreateToolWindow(_addin, _DockableWindowHost.RegisteredProgId,
                    control.Caption, control.ClassId, ref userControlObject);
            }
            catch (COMException exception)
            {
                var logEvent = new LogEventInfo(LogLevel.Error, _logger.Name, "Error Creating Control");
                logEvent.Exception = exception;
                logEvent.Properties.Add("EventID", 1);

                _logger.Error(logEvent);
                return null; //throw;
            }
            catch (NullReferenceException exception)
            {
                Debug.Print(exception.ToString());
                return null; //throw;
            }

            var userControlHost = (_DockableWindowHost)userControlObject;
            toolWindow.Visible = true; //window resizing doesn't work without this

            EnsureMinimumWindowSize(toolWindow);

            toolWindow.Visible = false; //hide it again

            userControlHost.AddUserControl(control as UserControl);
            return toolWindow;
        }
開發者ID:retailcoder,項目名稱:Rubberduck,代碼行數:35,代碼來源:DockableToolwindowPresenter.cs


注:本文中的NLog.LogEventInfo類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。