101

我们有一个 asp.net 4.0 项目,它使用了几个依赖于 log4net 版本 1.2.10.0 的框架。今天我尝试包含一个依赖于 log4net 版本 1.2.11.0 的新框架,从那以后我一直被卡住:

log4net 1.2.10.0 有 publickeytoken = 1b44e1d426115821

log4net 1.2.11.0 有 publickeytoken = 669e0ddf0bb1aa2a

由于这些不同,我不能通过 web.config 中的运行时元素使用程序集重定向(让所有框架使用相同版本的 log4net)或代码库(让新框架使用版本 1.2.11.0)。

我在这里有什么选择?

(以及为什么 log4net 会在版本之间不断更改 publickeytokens,据我所知,丢失的密钥是在版本 1.2.9.0 和 1.2.10.0 之间切换的原因,他们是否又丢失了密钥?我会自愿提供我的保管箱如果他们需要,请确保其安全...)

编辑:好的,所以 log4net 的家伙显然认为用两个键发布是个好主意,但这意味着你使用的每个框架都需要就他们喜欢的两种风格中的一种达成一致,否则这些框架不能工作并排在同一个应用程序域中。只有我一个人觉得这是个可怕的主意吗?如果每个人都这样做,那么一切都会崩溃,对吗?

Edit2:正如我所说,我没有在我的业务代码中使用 log4net,但我使用了几个依赖于 1.2.10.0 的框架,当我尝试使用依赖于 1.2.11.0 的新框架时出现问题(新键),所以 Stefans 的回答不适用,因为新框架会期待新的密钥,而不是旧的

4

6 回答 6

65

这就是我使用版本 1.2.11.0 的方式。

  1. 诅咒apache首先更改密钥:)
  2. 下载使用旧密钥签名的 1.2.11.0 版本。
  3. 通过删除对 log4net(新密钥)的任何直接引用来整理您自己的代码,并替换为对使用旧密钥签名的程序集的引用。
  4. 通过在您的 web/app.config 中包含此段来整理您可能拥有的任何依赖程序集
   <runtime>
        <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
            <dependentAssembly>
                <assemblyIdentity name="log4net" publicKeyToken="1b44e1d426115821" culture="neutral" />
                <bindingRedirect oldVersion="0.0.0.0-1.2.10.0"
                                 newVersion="1.2.11.0"/>
            </dependentAssembly>
        </assemblyBinding>
    </runtime>
于 2012-01-10T16:22:41.953 回答
28

我正在使用通过 nuget 下载的最新版本的 log4net。但是,我正在使用的库之一需要旧版本。我的烦恼使我想到了这个问题。

其他答案的问题是它们对所有绑定都使用相同的 dll 版本。我想将新版本中的功能用于除遗留依赖项之外的所有其他内容。

为了能够做到这一点,您需要执行以下操作:

  1. 首先下载旧版本(1.2.11.0 版本)。
  2. 将下载的二进制文件重命名为log4net.1.2.10.dll. 将其包含在您的启动项目中,并将构建操作设置为None和“如果较新则复制” 在此处输入图像描述
  3. 告诉 .NET 在哪里可以找到旧版本:

应用程序配置

<runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="log4net" publicKeyToken="1b44e1d426115821" />
            <codeBase version="1.2.10.0" href="log4net.1.2.10.dll" />
        </dependentAssembly>
    </assemblyBinding>
</runtime>

href属性标识旧版本的位置。因此,对 log4net 的所有其他请求都将指向新版本。

于 2014-11-13T13:13:22.540 回答
3

您可以下载使用旧密钥签名的 log4net 1.2.11.0 版本。他们的常见问题解答中解释了更改为新密钥的原因:

http://logging.apache.org/log4net/release/faq.html#two-snks

(基本上,新密钥是公开可用的,出于某种原因,他们不想在分发中包含旧密钥。我不清楚他们为什么不只是公开旧密钥)

于 2012-01-06T09:15:24.027 回答
1

不知道它是否适合您的特定情况,但您可以重新编译其中一个框架,因此它们将使用具有相同公钥的 log4net。在我的例子中,它是 FluentNHibernate,它使用 log4net 1.2.10 和 Combres 和 log4net 1.2.11 和新密钥。我下载了用旧密钥签名的 log4net 1.2.11 并用它重新编译了 Combress。之后添加了从 1.2.10 到 1.2.11 的程序集绑定重定向,它开始工作。

于 2012-05-14T21:24:15.043 回答
0

这不一定适用于所有情况,但是因为使用 log4net 的项目是 OSS,所以我下载了源代码,将 log4net 的冲突版本替换为我正在使用的版本并重建了项目。就我而言,它是 Topshelf,所以我现在有一个 Topshelf 程序集版本,它是用我正在使用的相同版本的 log4net 构建的,现在我可以毫无问题地引用两者。

于 2012-01-21T15:59:42.253 回答
0

我试图访问上面提供的链接,但似乎 Apache 站点中的所有链接都不起作用。然后这就是我为解决问题所做的:

在您的 Visual Studio 中,使用 Nuget 下载并安装最新版本的 log4net (1.2.13.0)。NuGet 包管理器会自动下载并升级所有 log4net(1.2.11.0) 到最新版本。

于 2015-05-28T22:22:20.177 回答