我正在尝试在我的asp.net Web应用程序中实现log4net。但不幸的是,文件未创建。以下是我的配置。
1。添加了log4net .dll参考
2。 Web.config设置。
<configSections>
<section name="log4net"type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
</configSections>
<log4net>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file type="log4net.Util.PatternString" value="E:/Log/error_%date{dd-MM-yyyy}.log"/>
<appendToFile value="true"/>
<rollingStyle value="Date"/>
<!--<maxSizeRollBackups value="5"/>
<maximumFileSize value="10MB"/>
<staticLogFileName value="true"/>-->
<datePattern value="yyyyMMdd" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %level %logger - %message%newline%exception%newline%newline"/>
</layout>
</appender>
<root>
<appender-ref ref="RollingFileAppender"/>
</root>
</log4net>
3。添加了程序集参考
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
4。记录在
背后的代码中private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
try
{
throw new System.IO.FileNotFoundException();
}
catch (Exception ex)
{
log.Error("Error error logging", ex);
}
这些是我遵循的步骤,但未创建日志......
请提出您的建议。
提前致谢
答案 0 :(得分:9)
确保您正在调用 XmlConfigurator 的配置功能。
请参阅此解决方案:Configure Log4Net in web application
答案 1 :(得分:5)
尝试在E:/ Log中为asp.net用户或Everyone提供写入权限, 然后尝试添加requirePermission =“false”属性,如下所示:
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net" requirePermission="false" />
或者你应该在root部分指定日志级别,如下所示:
<root>
<level value="ALL" />
<appender-ref ref="RollingFileAppender" />
</root>