C# WInForm之使用log4net输出两个日志文件

这里写自定义目录标题

前言

本文主要介绍使用log4net输出两种日志。一个日志存放在Logs文件夹下,用来记录相机流程。另一个日志存放在Data文件夹下,记录结果。因此需要配置log4net来定义两个日志记录器(Logger)。每个Logger可以有自己的Appender,决定日志的输出目的地(例如控制台、文件等)。

下载Log4Net包

在"工具"--"NuGet包管理器"--"管理解决方案的NuGet程序包"中安装"log4net"包。

在App.config定义两个Logger

1.打开解决方案下的"App.config"文件,如下图所示:

2.App.config中的代码如下:

csharp 复制代码
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
	<configSections>
		<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
	</configSections>

	<log4net>

		<!-- 第一个Logger -->
		<logger name="LogTrace1">
			<!-- 设置日志级别为"ALL",意味着这个Logger会记录所有级别的日志信息。在log4net中,日志级别从低到高分别为:DEBUG、INFO、WARN、ERROR、FATAL。-->
			<level value="ALL"/>
			<!-- 这是将这个Logger绑定到一个Appender,即"LogFileAppender1"。Appender决定了日志信息应该输出到哪里。在这个例子中,日志信息将被输出到"LogFileAppender1"所配置的地方。 -->
			<appender-ref ref="LogFileAppender1" />
		</logger>

		<!-- 第二个Logger -->
		<logger name="LogTrace2">
			<level value="ALL"/>
			<appender-ref ref="LogFileAppender2" />
		</logger>

		<!-- 文件Appender LogFileAppender1-->
		<appender name="LogFileAppender1" type="log4net.Appender.RollingFileAppender">
			<!--日志文件输出目录-->
			<param name="File" value="Logs\" />

			<!--True/false,默认为true。当文件存在时,是否在原文件上追加内容。-->
			<param name="AppendToFile" value="true"/>

			<!--创建新文件的格式(按日期)-->
			<param name="rollingStyle" value="Date" />

			<!--当RollingStyle为Composite或Date,这里设置文件名格式-->
			<param name="datePattern" value="yyyy-MM-dd'.log'" />

			<!--True/false,默认为true。为true时,RollingStyler的date值将无效。且为true时,需要在file里指定文件名,所有日志都会记录在这个文件里。-->
			<param name="staticLogFileName" value="false" />

			<!--备份日志数目,默认为0。在CountDirection为负数时有效。-->
			<maxSizeRollBackups value="10"/>


			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%n%date 【%p】 %message"/>
			</layout>
		</appender>

		<!-- 文件Appender LogFileAppender2-->
		<appender name="LogFileAppender2" type="log4net.Appender.RollingFileAppender">
			<!--日志文件输出目录-->
			<param name="File" value="Data\" />

			<!--True/false,默认为true。当文件存在时,是否在原文件上追加内容。-->
			<param name="AppendToFile" value="true"/>

			<!--创建新文件的格式(按日期)-->
			<param name="rollingStyle" value="Date" />

			<!--当RollingStyle为Composite或Date,这里设置文件名格式-->
			<param name="datePattern" value="yyyy-MM-dd'.log'" />

			<!--True/false,默认为true。为true时,RollingStyler的date值将无效。且为true时,需要在file里指定文件名,所有日志都会记录在这个文件里。-->
			<param name="staticLogFileName" value="false" />

			<!--备份日志数目,默认为0。在CountDirection为负数时有效。-->
			<maxSizeRollBackups value="10"/>


			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%n%date 【%p】 %message"/>
			</layout>
		</appender>


	</log4net>

	<startup>
		<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.7.2" />
	</startup>
</configuration>

3.右击App.config属性,将"复制到输出目录"中的"不复制"改为"如果较新则复制"

C# 代码

csharp 复制代码
 private void button1_Click(object sender, EventArgs e)
 {
     XmlConfigurator.Configure(new FileInfo("App.config"));  //这句代码相当于[assembly: log4net.Config.XmlConfigurator()],而且个人认为不必要再重新写一个类来实现这些方法
     //获取两个实例                                        
     var fileLogger1 = LogManager.GetLogger("LogTrace1");
     var fileLogger2 = LogManager.GetLogger("LogTrace2");
     // 记录日志到控制台和文件。这里记录的信息会分别发送到ConsoleAppender和FileAppender。  
     fileLogger1.Info("This is a message logged by ConsoleLogger");
     fileLogger2.Info("This is a message logged by FileLogger");
     fileLogger1.Debug("啥呀这是");
 }

参考链接

(1).代码部分参考链接:

参考链接:https://blog.csdn.net/HEIMENGER/article/details/120181289

(2)log4net配置文件的设置及常用参数讲解

参考链接:https://blog.csdn.net/hr541659660/article/details/45575473

相关推荐
测试界的酸菜鱼9 分钟前
Python 大数据展示屏实例
大数据·开发语言·python
时差95311 分钟前
【面试题】Hive 查询:如何查找用户连续三天登录的记录
大数据·数据库·hive·sql·面试·database
让学习成为一种生活方式12 分钟前
R包下载太慢安装中止的解决策略-R语言003
java·数据库·r语言
晨曦_子画18 分钟前
编程语言之战:AI 之后的 Kotlin 与 Java
android·java·开发语言·人工智能·kotlin
Black_Friend26 分钟前
关于在VS中使用Qt不同版本报错的问题
开发语言·qt
秋意钟39 分钟前
MySQL日期类型选择建议
数据库·mysql
希言JY1 小时前
C字符串 | 字符串处理函数 | 使用 | 原理 | 实现
c语言·开发语言
残月只会敲键盘1 小时前
php代码审计--常见函数整理
开发语言·php
xianwu5431 小时前
反向代理模块
linux·开发语言·网络·git
ktkiko111 小时前
Java中的远程方法调用——RPC详解
java·开发语言·rpc