winformpe配置log4net使用sqlite存储日志

 

 

1.安装log4net 

2.新建log4net.config 配置参考官方示例;

<?xml version="1.0" encoding="utf-8"?>
<configuration>
	<configSections>
		<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
	</configSections>
	<startup>
		<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
	</startup>
	<log4net>
		<logger name="CodeLog">
			<level value="INFO" />
			<appender-ref ref="RollingLog" />
			<appender-ref ref="SqliteAppender" />
			<appender-ref ref="ColoredConsoleAppender" />
		</logger>
		<appender name="RollingLog" type="log4net.Appender.RollingFileAppender">
			<file value="WindowsServiceLog\" />
			<appendToFile value="true" />
			<rollingStyle value="Date" />
			<datePattern value="yyyyMMdd'.txt'" />
			<staticLogFileName value="false" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="记录时间:%d 线程ID:[%thread]- 操作信息:%m%n" />
			</layout>
			<filter type="log4net.Filter.LevelRangeFilter">
				<param name="LevelMin" value="INFO" />
				<param name="LevelMax" value="INFO" />
			</filter>
		</appender>
		<!--sqlite数据库-->
		<appender name="SqliteAppender" type="log4net.Appender.AdoNetAppender">
			<bufferSize value="1" />
			<param name="Threshold" value="INFO" />
			<connectionType value="System.Data.SQLite.SQLiteConnection, System.Data.SQLite" />
			<connectionString value="Data Source=D:/testDB.db;Version=3;" />
			<commandText value="INSERT INTO Log (Date, Level, Logger, Message) VALUES (@Date, @Level, @Logger, @Message)" />
			<parameter>
				<parameterName value="@Date" />
				<dbType value="DateTime" />
				<layout type="log4net.Layout.RawTimeStampLayout" />
			</parameter>
			<parameter>
				<parameterName value="@Level" />
				<dbType value="String" />
				<layout type="log4net.Layout.PatternLayout">
					<conversionPattern value="%level" />
				</layout>
			</parameter>
			<parameter>
				<parameterName value="@Logger" />
				<dbType value="String" />
				<layout type="log4net.Layout.PatternLayout">
					<conversionPattern value="%logger" />
				</layout>
			</parameter>
			<parameter>
				<parameterName value="@Message" />
				<dbType value="String" />
				<layout type="log4net.Layout.PatternLayout">
					<conversionPattern value="%message" />
				</layout>
			</parameter>
		</appender>
		<!--控制台-->
		<appender name="ColoredConsoleAppender"  type="log4net.Appender.ColoredConsoleAppender" >
			<mapping>
				<level value="DEBUG" />
				<backColor value="Green" />
			</mapping>
			<layout type="log4net.Layout.PatternLayout">
				<param name="ConversionPattern" value="%d [%t] %F-%L-%c/%p--message:%m%n" />
				<!--<param name="ConversionPattern"  value="%n%d 程序运行时间:%r毫秒 进程ID:%t 行号:%L %n 当前日志对象名称:%c 日志当前级别:%p 输出语句所在文件名:%F 日志消息:%m" />-->
			</layout>
		</appender>
	</log4net>
</configuration>

3.入口文件中读取配置文件

 log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo("log4net.config"));

4.程序内使用

log4net.ILog ILog = log4net.LogManager.GetLogger("MdTools.Logging");
ILog.error("123")

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值