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

相关推荐
程序边界几秒前
深度Oracle替换工程实践的技术解读(上篇)
数据库·oracle
lly202406几秒前
HTML5 测验
开发语言
吴声子夜歌1 分钟前
JavaScript——字符串和正则表达式
开发语言·javascript·正则表达式
林恒smileZAZ1 分钟前
JavaScript this绑定规则:告别踩坑指南!
开发语言·javascript·ecmascript
2401_873204655 分钟前
C++代码重构实战
开发语言·c++·算法
crossoverJie5 分钟前
OpenAI 收购 Python 工具链 uv 和 Ruff
开发语言·人工智能·python·uv
ofoxcoding7 分钟前
GPT-5.4 Mini vs Nano 怎么选?2026 实测对比,一张表说清楚
开发语言·gpt·ai·php
2401_831824969 分钟前
RESTful API设计最佳实践(Python版)
jvm·数据库·python
NGC_66119 分钟前
深入理解 Java 线程池:从原理到实战
java·开发语言·python
xiaolang_8616_wjl10 分钟前
c++游戏_寻宝猎人_开源
开发语言·c++