C# log4net配置

1.通过管理NuGet程序包 引入log4net.dll程序集
管理NuGet程序包 引入log4net.dll程序集
2.配置log4netConfig.xml文件

<?xml version="1.0" encoding="utf-8" ?>
<!--在asp.net下存在着一个名为App_Data的文件夹,这个文件夹有特殊的作用。
App_Data文件夹的作用是存放web应用所需的数据文件,如数据库文件、XML数据文件等,-->
<configuration>
  <log4net>
     <!--定义输出到文件中-->
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <!--定义文件存放位置-->
      <param name="File" value="systemLog/" />
      <param name="AppendToFile" value="true" />
      <param name="MaxSizeRollBackups" value="10" />
      <param name="StaticLogFileName" value="false" />
      <param name="DatePattern" value="yyyy-MM\\yyyy-MM-dd\\yyyy-MM-dd'-info.txt'" />
      <param name="RollingStyle" value="Date" />
      <param name="lockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <layout type="log4net.Layout.PatternLayout">
        <!--输出格式-->
        <!--每条日志末尾的文字说明-->
        <!--输出格式-->
        <!--样例:2008-03-26 13:42:32,111 [10] INFO  Log4NetDemo.MainClass [(null)] - info-->
        <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss:fff} [%thread] %-5level %logger %ndc - %message%newline" />
      </layout>
    </appender>
    <appender name="ErrorLogAppender" type="log4net.Appender.RollingFileAppender">
      <param name="File" value="systemLog/" /> <!--日志输出到exe程序这个相对目录下-->
      <param name="AppendToFile" value="true" /> <!--输出的日志不会覆盖以前的信息-->
      <param name="MaxSizeRollBackups" value="10" /> <!--备份文件的个数-->
      <param name="StaticLogFileName" value="false" /> <!--是否使用静态文件名-->
      <param name="DatePattern" value="yyyy-MM\\yyyy-MM-dd\\yyyy-MM-dd'-error.txt'" /> <!--日志文件名-->
      <param name="RollingStyle" value="Date" /> <!--文件创建的方式,这里是以Date方式创建-->
      <param name="lockingModel" type="log4net.Appender.FileAppender+MinimalLock" />
      <!--信息日志布局-->
      <layout type="log4net.Layout.PatternLayout">
        <!--输出格式-->
        <!--每条日志末尾的文字说明-->
        <!--输出格式-->
        <!--样例:2008-03-26 13:42:32,111 [10] INFO  Log4NetDemo.MainClass [(null)] - info-->
        <param name="ConversionPattern" value="%date 线程ID:[%thread] 日志级别:%-5level 出错类:%logger property:[%property{NDC}] - 错误描述:%message%newline" />
      </layout>
    </appender>
    <root>
    </root>
    <logger additivity="true" name="InfoLog">
      <level value="INFO" />
      <!--文件形式记录日志-->
      <appender-ref ref="RollingLogFileAppender" />
    </logger>
    <logger additivity="true" name="ErrorLog">
      <level value="ERROR" />
      <appender-ref ref="ErrorLogAppender" />
    </logger>
  </log4net>
</configuration>

3.新建公共方法类Log4NetHelper

public class Log4NetHelper
    {
        private static readonly ILog Loginfo = LogManager.GetLogger("InfoLog");
        private static readonly ILog Logwarn = LogManager.GetLogger("Warn");
        private static readonly ILog Logerror = LogManager.GetLogger("ErrorLog");
        private static readonly ILog Logfatal = LogManager.GetLogger("Fatal");
        static Log4NetHelper()
        {
            var configFile = HostingEnvironment.MapPath("/App_Data/Log4netConfig.xml");
            log4net.Config.XmlConfigurator.Configure(new FileInfo(configFile));
            //log4net.Config.XmlConfigurator.Configure();
        }
         private static string GetMethodInfo()
        {
            StackTrace ss = new StackTrace(true);
            //index:0为本身的方法;1为调用方法;2为其上上层,依次类推
            MethodBase mb = ss.GetFrame(2).GetMethod();
            string systemModule =
                $"{Environment.NewLine}模块名:{mb.Module}{Environment.NewLine}命名空间名:{mb.DeclaringType?.Namespace}{Environment.NewLine}类名:{mb.DeclaringType?.Name}{Environment.NewLine}方法名:{mb.Name}";
            return systemModule;
        }
                public static void Info(string msg)
        {
            Loginfo.Info($"{GetMethodInfo()}——{msg}");
        }
                public static void Error(string msg)
        {
            Logerror.Error($"{GetMethodInfo()}——{msg}");
       }
         }
        }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梦想家NO1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值