.net log4net中的动态名称

.net log4net中的动态名称,.net,log4net,log4net-configuration,.net,Log4net,Log4net Configuration,我正在尝试为日志配置动态名称,但无法: 以下是我的web.config文件中的代码: <appender name="RollingFile" type="log4net.Appender.RollingPatternFileAppender"> <file type="log4net.Util.PatternString" value="..l\log\%property{LogName}" /> <appendToFile value="true" /&

我正在尝试为日志配置动态名称,但无法:

以下是我的
web.config
文件中的代码:

<appender name="RollingFile" type="log4net.Appender.RollingPatternFileAppender">
  <file type="log4net.Util.PatternString" value="..l\log\%property{LogName}" />
  <appendToFile value="true" />
  <rollingStyle value="Size" />
  <maxSizeRollBackups value="-1" />
  <maximumFileSize value="5000KB" />
  <staticLogFileName value="true" />
  <countDirection value="1"/>
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%m%n" />
  </layout>
  <filter type="log4net.Filter.PropertyFilter">
    <Key value="Version" />
    <StringToMatch value="1" />

  </filter>
  <filter type="log4net.Filter.DenyAllFilter" />

  <root>
    <level value="DEBUG"/>
    <appender-ref ref="RollingFile"/>
  </root>

</appender>
<logger name="File">
  <level value="All" />
  <appender-ref ref="RollingFile" />
</logger>
代码隐藏:

log = LogManager.GetLogger(
            System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
log4net.ThreadContext.Properties["LogName"] = 
            sito + "_Truck_Log_" + DateTime.Today.ToString("dd-MM-yyyy") + ".txt";
log4net.GlobalContext.Properties["LogName"] = 
           sito + "_Truck_Log_" + DateTime.Today.ToString("dd-MM-yyyy")+".txt";
log = LogManager.GetLogger(
           System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
这不会创建任何日志文件吗?为什么会这样

更新1:

我已经移动了
log4net.Config.XmlConfigurator.Configure()在设置线程上下文属性之后,但仍然不起作用

更新2:

@sgmoore:我确信我没有权限问题,而且我确信“sito”变量不包含无效字符。我正在做这样的事情:

在我的代码背后:

log = LogManager.GetLogger(
            System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
log4net.ThreadContext.Properties["LogName"] = 
            sito + "_Truck_Log_" + DateTime.Today.ToString("dd-MM-yyyy") + ".txt";
log4net.GlobalContext.Properties["LogName"] = 
           sito + "_Truck_Log_" + DateTime.Today.ToString("dd-MM-yyyy")+".txt";
log = LogManager.GetLogger(
           System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
global.asax中

log4net.Config.XmlConfigurator.Configure();
void Application_Start(object sender, EventArgs e) 
{
     log4net.Config.XmlConfigurator.ConfigureAndWatch(
          new System.IO.FileInfo(
            AppDomain.CurrentDomain.SetupInformation.ApplicationBase 
                                                       + "log4net.config")); 
}

但这仍然不起作用。

您必须在配置log4net之前设置thread context属性。

您必须在配置log4net之前设置thread context属性。

既然您说它不创建任何文件,您确定这不是权限问题吗?(即,如果您不尝试使用动态名称,它是否会在正确的位置创建文件?) 另外,您确定sito变量不包含无效字符吗

我会尽可能早地设置该属性,因为它可能会在设置LogName属性之前尝试对其求值。(即在GetLogger、Configure或任何实际日志记录之前进行设置)


(我做了类似的事情,但在Winforms应用程序中,我使用log4net.GlobalContext.Properties,而不是log4net.ThreadContext.Properties,这两个属性显然使事情更简单)。

既然您说它不创建任何文件,您确定这不是权限问题吗?(即,如果您不尝试使用动态名称,它是否会在正确的位置创建文件?) 另外,您确定sito变量不包含无效字符吗

我会尽可能早地设置该属性,因为它可能会在设置LogName属性之前尝试对其求值。(即在GetLogger、Configure或任何实际日志记录之前进行设置)


(我做了类似的事情,但在Winforms应用程序中,我使用log4net.GlobalContext.Properties,而不是log4net.ThreadContext.Properties,这两个属性显然使事情变得更简单)。

我已经移动了log4net.Config.XmlConfigurator.Configure();之后设置线程上下文属性,但仍然无法工作。我已经移动了log4net.Config.XmlConfigurator.Configure();之后,设置线程上下文属性,但仍不起作用。相关已解决问题:相关已解决问题: