将log4net 1.2.11添加到项目中,使用日志功能。
网上很多,下面简要说说他的步骤:
1.下载log4net,现在的最新版是1.2.11
2.引用log4net.dll
3.在AssemblyInfo.cs文件中添加
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
4.添加app.config(WinForm)或者在web.config当然也可以指定其他的文件名。但是在上一步添加ConfigFile属性即可。
5.编辑app.config,整理正确的如下: 注意编辑完app.config文件关闭然后编译,否则可能出现如题所示的message.
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<root>
<level value="ALL" />
<appender-ref ref="SysAppender" />
</root>
<appender name="SysAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="Log\logs" />
<param name="AppendToFile" value="true" />
<param name="MaxSizeRollBackups" value="30" />
<param name="MaximumFileSize" value="100MB" />
<param name="RollingMode" value="Date" />
<param name="DatePattern" value="'_'yyyy-MM-dd'.txt'" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%date [%thread] %-5level %logger [%method] %L [%exception] - %message%newline" />
</layout>
</appender>
</log4net>
</configuration>
6.在程序中使用
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
log.Debug("test");即可。
刚开始出现如题所示的错误,我也找了很长时间。并且重新创建个新项目来测试。知道最后还是出现这个信息。当然了,假如你关闭app.config就不出现了。
假如配置正确,运行没有出现错误提示都应该出现日志。
只要调试的时候log不等于null。其他的就应该是app.config 设置错误。
我曾经在C++用过有DailyRollingFileAppender,而.net中没有。不知道是1.2.11给删除了还是就没有。旧版本没用过。