2

我创建了以下自定义目标:

[Target("MyTarget")
public class MyTarget : TargetWithLayout

这个类是在它自己的程序集中定义的,比如说 MyTargets.dll(不是实名)。NLog.config 文件有以下几行

<extensions>
    <add assembly="MyTargets, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />
</extensions>

已定义一个目标以使用这种新类型:

<target name="myTarget" xsi:type="MyTarget" />

已经定义了一个记录器来使用这个目标(省略)。

如果我引用目标程序集项目,我的应用程序将成功加载配置。如果我尝试引用输出 DLL,它将无法加载。如果我以编程方式从程序集中添加目标(bin 引用而不是项目),那么它可以工作。

DLL 似乎在正确的位置,即 bin 目录。该类型必须存在,因为我可以在代码中引用该类型,但是在尝试在代码中引用该类型时它似乎失败了。

为什么不直接用代码来做呢?好吧,它是我正在构建的 nuget 包的一部分,我想要一个标准配置文件分发给这个代码库的所有使用者。

任何建议/想法将不胜感激

4

1 回答 1

3

原来我是个白痴。

由于不相关的原因,我决定在构建时将 NLog.config 文件复制到 bin 目录,同时将原始文件保留在根项目级别。这在 NLog 中引起了某种冲突。

当我从 bin 目录中删除配置文件时,根级别的配置文件会正确加载,并且我的自定义目标会按预期找到。如果我从项目根目录中删除配置文件并将其放在 bin 目录中(即与包含自定义目标的程序集相同的级别),则加载的配置文件将无法找到自定义目标。

回顾一下,我不再将配置文件放在 bin 目录中,而是将其保留在定义的位置(项目根级别)

于 2011-06-10T14:32:17.303 回答