我有使用NLog的Windows Forms应用程序NET 4.5(VS 2013)。

我有目标:

<target name="asyncFileLog" xsi:type="AsyncWrapper">
  <target name="logfileTrace" xsi:type="File" fileName="${basedir}/logs/${shortdate}Trace.log" layout="${longdate} ${message}" lineEnding="Default"/>
</target>

<target name="asyncFileError" xsi:type="AsyncWrapper">
  <target name="logfileError" xsi:type="File" fileName="${basedir}/logs/${shortdate}Error.log" layout="${longdate} ${message} ${exception:format=tostring}"  lineEnding="Default"/>
</target>
LogManager.Configuration.AllTargets.ToList();返回4个项目,而不是2个项目。

我想在运行时以编程方式更改路径 $ {basedir}/logs

我尝试这样:
var rutaLogs = ConfigurationManager.AppSettings["RutaLog"];
if (!Directory.Exists(rutaLogs)) return;

var list = LogManager.Configuration.AllTargets.ToList();
foreach (var target in list)
{
    FileTarget fileTarget = null;
    var wrapperTarget = target as WrapperTargetBase;

    // Unwrap the target if necessary.
    if (wrapperTarget == null)
    {
        fileTarget = target as FileTarget;
    }
    else
    {
        fileTarget = wrapperTarget.WrappedTarget as FileTarget;
        continue;
    }

    var value = fileTarget.FileName.ToString();
    value = value.Replace("${basedir}/logs/", rutaLogs);
    fileTarget.FileName = value;
}

不产生任何东西。
我也尝试使用LogManager.ReconfigExistingLoggers();,但无法正常工作。

有什么建议么?

最佳答案

在这种情况下,使用变量会更容易。 (${var:...})

对于此示例:

<variable name="basedir" value="${basedir}" />    <!-- default, optional -->

<targets>
   <target name="asyncFileLog" xsi:type="AsyncWrapper">
     <target name="logfileTrace" xsi:type="File"
             fileName="${var:basedir}/logs/${shortdate}Trace.log"
             layout="${longdate} ${message}" lineEnding="Default"/>
   </target>
   ...

在C#中更改变量
// create or edit
LogManager.Configuration.Variables["basedir"] = "d:/mybasedir";

无需LogManager.ReconfigExistingLoggers();或遍历所有目标!

另请参阅 ${var} documentation

更新:在这种情况下,您正在从.config文件读取,这可以仅通过NLog配置来完成(不需要C#!)

安装NLog.Extended并使用${appsetting:name=..}
例如
fileName="${var:basedir}/logs/${appsetting:name=RutaLog}Trace.log"

另请参阅 ${appsetting} documentation

关于c# - 在运行时以编程方式更改NLog目标中的basedir,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42550795/

10-12 00:11
查看更多