WPF如何使用log4net

一 安装配置log4net

1. 下载log4net
选择生成的项目,右键,再选择‘Manage NuGet Packages’在这里插入图片描述

2. 搜索log4net,并安装
在这里插入图片描述

1. 选择生成的项目,右键添加‘App.config’
在这里插入图片描述
4. 写配置文件
在上一步生成的App.config中写log4net的配置文件

<configurattion>
	<configSections>
		<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
	</configSections>
	<log4net>
		<root>
			<level value="ALL"/>			
		</root>
		<logger name="OperationLog">
			<level value="INFO"/>
			<appender-ref ref="OperationLogAppender"/>
		</logger>
		<logger name="ErrorLog">
			<level value="WARN"/>
			<appender-ref ref="ErrorLogAppender"/>
		</logger>
			<!--定义输出到文件中-->
			<appender name="OperationLogAppender" type="log4net.Appender.RollingFileAppender,log4net">
				<!--输出日志文件的路径-->
				<param name="File" value="Log/OperationLog"/>
				<!--输出日志时自动向后追加-->
				<param name="AppenderToFile" value="true"/>
				<!--防止多线程时不能写Log,官方说线程非安全,但实际使用时,本地测试正常,部署后有不能写日志的情况-->
				<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
				<!--日志以大小作为备份样式,还有一种方式是Date(日期)-->
				<param name="RollingStyle" value="size"/>
				<!--单个日志的最大容量,(可用的单位:KB|MB|GB)不要使用小数,否则会一直写入当前日志-->
				<param maximumFileSize value="3M"/>
				<!--日志最大个数,都是最新的-->
        		<maxSizeRollBackups value="10" />
				<param name="DatePattern" value="yyyyMMdd&quot;.log&quot;"/>
				<!--置为true,当前最新日志文件名永远为file节中的名字-->
				<param name="StaticLogFileName" value="false"/>
				 <!--输出格式-->
          <!--样例:2008-03-26 13:42:32,111 [10] INFO  ErrorLog  - info-->
				<layout type="log4net.Layout.PatternLayout,log4net">
					<param name="ConversionPattern" value="%d[%t]%-5p %c - %m%n"/>
				</layout>
			</appender>
			<appender name="ErrorLogAppender" type="log4net.Appender.RollingFileAppender,log4net">
				<!--<param name="File" type="log4net.Util.PatternString" value="Log/OperationLog"/>-->
				<param name="File" value="Log/ErrorLog"/>
				<param name="AppenderToFile" value="true"/>
				<param name="RollingStyle" value="Composite"/>
				<param name="DatePattern" value="yyyyMMdd&quot;.log&quot;"/>
				<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>

5. 配置文件拷贝到目标目录
选择App.config, 在属性栏把Copy to Output Directoru项选为copy if newer
在这里插入图片描述

6. 给log4net文件名赋值

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "App.config", ConfigFileExtension = "config", Watch = true)]
namespace Xxxxx
{
	public partial class App:Application
	{
		public static log4net.ILog operationLog = log4net.LogManager.GetLogger("OperationLog");
		public static log4net.ILog errorLog = log4net.LogManager.GetLogger("ErrorLog");
		
	}
}

7. 写入log信息

public partial class MainWindow: Window
{
	public MainWindow()
	{
		App.errorLog.Infor("启动程序");
	}
	
}
private void Button_Click(object sender,RoutedEventArgs e)
{
	App.OperationLog.Info("按下开始按钮");
}

实例演示
在这里插入图片描述

二 log4net配置文件中XML转义字符

转义字符字符
&amp&
&lt<
&gt>
&quot"
&apos
&nbsp空格
&copy©(版权符)
&reg®(注册符)

三 log4net配置文件中ConversionPattern的代码解释

代码意思解释
%mmessage输出日志消息
%nnew line换行
%ddatetime输出当前语句的运行时间
%rruntime输出程序从运行到执行当前语句时消耗的毫秒数
%tthread id输出当前语句所在的线程ID
%ppriority日志的当前优先级,DEBUG,INFO,WARN…
%cclass当前日志对象的名称
%L
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

fwsylin

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

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

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

打赏作者

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

抵扣说明:

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

余额充值