• Winform 中 Log4net 配置写不同文件


    以下配置了二种写文件,第一种根据日期写文件yyyyMMdd.txt,第二种是写固定文件login.txt。


    1, 下载Log4net组件:
    http://logging.apache.org/log4net/download.html

    2,将log4net.dll加到项目引用中;
     
    3,在app.config中添加相关配置信息,文件内容如下:

       <?xml version="1.0"?>
    <configuration>
      <configSections>
        <sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
          <section name="ChinaBank.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false"/>
        </sectionGroup>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net-net-1.0"/>
      </configSections>
      <log4net>
        <logger name="Daily.Logging">
          <level value="INFO"/>
          <appender-ref ref="DailyAppender" />
        </logger>
        <logger name="Login.Logging">
          <level value="INFO"/>
          <appender-ref ref="LoginAppender" />
        </logger>
        <appender name="DailyAppender" type="log4net.Appender.RollingFileAppender,log4net" >
          <param name="File" value="Logs/" />
          <param name="AppendToFile" value="true" />
          <param name="RollingStyle" value="Date" />
          <param name="DatePattern" value="yyyyMMdd.'txt'" />
          <param name="StaticLogFileName" value="false" />
          <layout type="log4net.Layout.PatternLayout,log4net">
            <param name="ConversionPattern" value="%m%n" />
          </layout>
        </appender>
        <appender name="LoginAppender" type="log4net.Appender.RollingFileAppender,log4net" >
          <param name="File" value="Logs/login.txt" />
          <param name="AppendToFile" value="true" />
          <layout type="log4net.Layout.PatternLayout,log4net">
            <param name="ConversionPattern" value="%d|%m|%n" />
          </layout>
        </appender>
      </log4net>
    <!--这里为appSettings等其它节点信息-->
    </configuration>
     
     
    4,在AssemblyInfo.cs最下面添加(其中XXXXX.exe.config为app.config在bin\Debug中生成的文件名,以实际为准):
    [assembly: log4net.Config.XmlConfigurator(ConfigFile = "./XXXXX.exe.config", ConfigFileExtension = "config", Watch = true)]
     


    5,在项目中使用Log4net:

    //根据日期写文件yyyyMMdd.txt
    log4net.ILog log = log4net.LogManager.GetLogger("Daily.Logging");  
    log.Info("这是一条普通信息");    

    //写固定文件login.txt
    log4net.ILog log2 = log4net.LogManager.GetLogger("Login.Logging");
    log2.Info("用户张三登录");

    --------------------------------------------------------------------------------------

    备注:

    1、以上是WinForm的配置,WebForm配置也一样,只是换成web.config。

    2、log4net的配置也可以单独写在一个配置文件中,如log4net.config。

    下面为log4net.config例子:

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
    <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
    </configSections>
    <log4net>
    <logger name="logging">
    <level value="INFO"/>
    <appender-ref ref="appender"/>
    </logger>
    <appender name="appender" type="log4net.Appender.RollingFileAppender,log4net" >
    <param name="File" value="D:/logs/"/>
    <param name="AppendToFile" value="true"/>
    <param name="RollingStyle" value="Date"/>
    <param name="DatePattern" value="'test_'yyyyMMdd.'txt'"/>
    <param name="StaticLogFileName" value="false"/>
    <layout type="log4net.Layout.PatternLayout,log4net">
    <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n"/>
    </layout>
    </appender>
    </log4net>
    </configuration>

    打开项目目录Properties里面的文件AssemblyInfo.cs,在最后面添加一行
    [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]
    说明:log4net.config放在项目根目录,这里路径就可以直接这样写。

  • 相关阅读:
    Shell编程-02-Shell变量
    Linux 下强大的查找命令find
    DevOps 学院
    史上最详细、最全面的Hadoop环境搭建
    Linux 中10个命令链接操作符,帮助新手快速入门运维!
    25个Linux性能监控工具
    一文详解 Linux系统常用监控工具
    ansible 安装指南
    Tomcat管理页面
    Tomcat基础知识
  • 原文地址:https://www.cnblogs.com/gdjlc/p/2812509.html
Copyright © 2020-2023  润新知