C# 代碼 手工 配置 Log4Net 2種方法

這個初始化要在 獲取 ILog 接口的代碼以前完成, 以後按一般方式使用 log4net 就好了.app

不用攜帶 config 配置文件.編碼

方法1:url

        /// <summary>
        /// 使用文本記錄異常日誌
        /// </summary>
        /// <Author>Ryanding</Author>
        /// <date>2011-05-01</date>
        public void LoadFileAppender()
        {
            string currentPath = AppDomain.CurrentDomain.BaseDirectory;
            currentPath = Path.Combine(currentPath, @"Log");

            string txtLogPath = Path.Combine(currentPath, "ErrorLog.txt");

            log4net.Repository.Hierarchy.Hierarchy hier =
                (log4net.Repository.Hierarchy.Hierarchy)log4net.LogManager.GetRepository();

            if (hier != null)
            {
                FileAppender fileAppender = new FileAppender();
                fileAppender.Name = "LogFileAppender";
                fileAppender.File = txtLogPath;
                fileAppender.AppendToFile = true;

                PatternLayout patternLayout = new PatternLayout
                {
                    ConversionPattern =
                        "記錄時間:%date 線程ID:[%thread] 日誌級別:%-5level 出錯類:%logger property:[%property{NDC}] - 錯誤描述:%message%newline"
                };
                patternLayout.ActivateOptions();
                fileAppender.Layout = patternLayout;

                //選擇UTF8編碼,確保中文不亂碼。
                fileAppender.Encoding = Encoding.UTF8;

                fileAppender.ActivateOptions();
                BasicConfigurator.Configure(fileAppender);
            }
        }

 

方法2:spa

    static bool InitializeLogSystem()
    {
      // 經過配置文件偷來的配置項
      //<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      //  <file value="Data/RollingLogFile.log" />
      //  <appendToFile value="true" />
      //  <maxSizeRollBackups value="3" />
      //  <maximumFileSize value="1MB" />
      //  <rollingStyle value="Size" />
      //  <staticLogFileName value="true" />
      //  <layout type="log4net.Layout.PatternLayout">
      //    <conversionPattern value="%date [%thread] %-5level %logger [%property{url}] - %message%newline" />
      //  </layout>
      //</appender>
      log4net.Appender.RollingFileAppender appender = new log4net.Appender.RollingFileAppender();
      // winform 的取路徑方式呢
      appender.File = System.IO.Path.Combine(Application.StartupPath, "RollingLogFile.log");
      appender.AppendToFile = true;
      appender.MaxSizeRollBackups = 3;
      appender.MaximumFileSize = "1MB";
      appender.RollingStyle = log4net.Appender.RollingFileAppender.RollingMode.Size;
      appender.StaticLogFileName = true;
      appender.Layout = new log4net.Layout.PatternLayout("%date [%thread] %-5level - %message%newline");
      appender.ActivateOptions();// 這個要調用一下呢
      log4net.Config.BasicConfigurator.Configure(appender);
      return true;
    }
相關文章
相關標籤/搜索