- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Nuget 更新后,我已经为 DLL hell 苦苦挣扎了一个多星期。我已经通过手动编辑解决方案、项目和包文件解决了大部分问题。但是,无论我做什么,VS 都坚持认为 dll 的版本与 Nuget 安装的版本不同。有问题的库是 MailKit,在更新之前它工作正常。现在安装的版本是 2.4.1,但是尽管显示了正确的位置,属性网格仍然坚持版本 2.4.0:
我已经尝试了以下所有方法,但都没有成功:
无论我做什么,它仍然显示错误的版本,因此当应用程序运行时它会抛出异常,因为正确的版本已复制到本地。
谁能建议我如何解决这个问题?
编辑:
包配置:
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="BouncyCastle" version="1.8.5" targetFramework="net452" />
<package id="JetBrains.Annotations" version="2019.1.3" targetFramework="net452" />
<package id="MailKit" version="2.4.1" targetFramework="net452" />
<package id="MimeKit" version="2.4.1" targetFramework="net452" />
</packages>
项目文件(仅引用 MailKit 和 MimeKit,其余部分已删除,如果需要更多请告诉我):
<Reference Include="MailKit, Version=2.4.1, Culture=neutral, PublicKeyToken=4e064fe7c44a8f1b, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\packages\MailKit.2.4.1\lib\net45\MailKit.dll</HintPath>
</Reference>
<Reference Include="MethodExtensions, Version=1.0.4469.11621, Culture=neutral, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\..\Libraries\MethodExtensions\bin\Debug\MethodExtensions.dll</HintPath>
</Reference>
<Reference Include="MimeKit, Version=2.4.1, Culture=neutral, PublicKeyToken=bede1c8a46c66814, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>..\packages\MimeKit.2.4.1\lib\net45\MimeKit.dll</HintPath>
</Reference>
进一步编辑:
说明一下,包安装的dll版本明明是2.4.1:
这是确认它正在寻找 2.4.0 的运行时错误消息,它在 Nuget 更新后不再位于计算机上:
解决方案
@zivkan 的回答为我指明了正确的方向。首先,我在寻找完全错误的东西,假设 Property Grid 中的版本不正确,而实际上它完全没问题。该引用位于一个插件模块中,该模块本身编译为一个库,这意味着在编译 MailKit dll 时,不仅必须将其复制到本地,而且还要使用后期构建事件命令行将其复制到主应用程序文件夹。原来是post build事件代码出错,导致MailKit没有被复制,而MimeKit被复制了两次。不怪那个,怪我没认清问题!
感谢@zirkan,你的帮助和解释最终让我达成了解决方案......
最佳答案
when the app runs it throws an exception since the correct version is copied local.
你的意思是不正确?如果复制了正确的版本,我不明白为什么会抛出异常。无论如何,如果您向我们展示您遇到的实际错误,将会更有帮助。我将用这个答案的其余部分来解释为什么其他一切都按设计工作,这意味着您没有给我们足够的信息来理解您的问题,因此很难提出好的解决方案。
无论如何,NuGet 包只是一个 zip 文件(重命名为 .nupkg
),其中包含一些文件,通常是一些 .NET 程序集。那么,放弃基本问题,如果包中的不同程序集有不同的版本会怎样?答案是什么都没有,因为程序集版本和包版本是独立的。它们通常很相似,或者(几乎)完全相同,但由于它们是独立的,所以没有理由不一样。
一个程序集也有多个版本。首先,如果您在 Windows 资源管理器中找到 .dll
,右键单击,选择属性并转到详细信息选项卡,您将看到所有(或大多数)dll 都有产品版本和文件版本.这不是 .NET 特有的,所有 Windows 可执行文件都有此元数据。如果您使用 ILSpy 或类似的东西来检查 .NET 程序集,您会看到有 AssemblyFileVersion、AssemblyInformationalVersion 和 AssemblyVersion 属性。所以总共有至少 5 个不同的版本元数据,它们都是独立的,因此可以不同。那是在我们认为 NuGet 包版本是第 6 个独立版本号之前。
现在,属性窗口中的程序集对 NuGet 一无所知。它显示文件的路径,由于 NuGet 将包提取到包含包版本的路径,我们可以在路径中看到它。但是属性窗口中显示的版本是程序集版本。因此,在这种情况下,MailKit v2.4.1 程序包包含 MailKit.dll,程序集版本为 2.4.0.0。 Visual Studio 的属性窗口显示正确的信息,没有问题。
我的回答已经够长了,所以我不会详细介绍,但包作者可能会选择在其包的多个版本中使用相同的程序集版本,以最大限度地减少需要绑定(bind)重定向的次数。但是,这仅在不同产品版本兼容时才有效。当它们不兼容并且两个不同的程序集都依赖于同一个程序集版本的依赖项时,不可能同时加载两个不同的版本来解决这个问题(是的,当同一个程序集具有不同的程序集版本时, 可以同时加载两者,只是需要额外的努力)。
关于c# - 我如何解决 Nuget DLL Hell - 无论我做什么 VS 都坚持认为 dll 版本与包中的版本不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59229762/
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
class Person def name puts "Doharey" end end puts Person.class #=> this out puts Class puts
在 PHP 中,($myvariable==0)当 $myvariable 为零时,表达式的值为真;当 $myvariable 为 null 时,此表达式的值也为 true。如何排除第二种情况?我的意
正文 Oracle的一顿猛如虎操作,让开发者彻底失去了Java EE。Eclipse基金会则自立门户,另起炉灶开启Jakarta EE项目。 对于Jakarta EE,从它
我是 python 新手,建议我使用 Canopy。我正在努力跟进 with this tutorial ,但我陷入了 mahotas.imread 行。我收到一个错误,说以这个结尾: Full er
上下文是我们想要跟踪应用程序的用户行为,因为它具有不同的功能。 为此,我们创建了一个自定义 Angular Directive(指令),例如myFunctionality并将 HTML 部分包装到此指
我正在尝试在文本字段中实现 google Places api 的自动完成功能。这是我的代码: $(document).ready(function() { initialize(){ v
我在 Glassfish 3.1.1 中配置了一个新的 jdbcRealm 并打开了 FINEST 日志记录,当我尝试使用用户名和密码登录时,我得到以下信息。它提示我的 Web 应用程序映射到的领域是
问题是,即使我将线程设置为“thrd.IsBackground = false”,iis 也不认为它正在运行,即使这是一个长时间运行的进程。如果我不关闭应用程序池的空闲关闭,它将关闭,因为它认为它是空
我正在使用 OpenJDK 8(从 https://jdk.java.net/java-se-ri/8 下载并解压,添加到 PATH),并且遇到了证书错误。 经过调查,我意识到 cacerts 存在问
我基于 Firebase 制作了简单的后期制作项目。我将帖子保存到 Firebase 中,如下所示: let data = UIImageJPEGRepresentation(newPostImage
我觉得还是先说明情况比较好。 情况 我正在编写一些软件来过滤 Set 的 File。 过滤器如下:如果文件未隐藏,则将其添加到新的 Set。 问题在于 File.isHidden() 的当前行为如下:
我创建了一个 C++ DLL 函数,它使用多个数组来处理最终的图像数据。我正在尝试通过引用传递这些数组,进行计算,然后通过预分配数组中的引用将输出传回。在该函数中,我使用了 Intel Perform
我在 python 中有一个小应用程序,除了这个小问题之外,它工作得很好:它应该连续运行一个循环,直到用户通过按钮告诉它停止,但是当我点击开始按钮时,Windows 告诉我它不是回应。现在,如果我编写
代码运行正常,但我怎么会得到这个错误日志 错误日志: 08-28 08:44:24.281: E/MediaPlayer(32454): mOnVideoSizeChangedListener is
我有一个使用 Karma+Jasmine 和 JSHint 的 Grunt 设置。每当我在我的规范文件上运行 JSHint 时,我都会收到一系列“未定义”错误,其中大部分是针对 Jasmine 的内置
将以下代码保存到文件中,Ubuntu 14.04 正确地意识到它是 bash: #!/usr/bin/env bash awk '{print $1 $2}' my_file 然而,向 awk 添加关
以下代码返回 false import inspect print(inspect.isbuiltin(map)) 但是 map 功能在"built-in" functions下列出. 为什么会这样?
这是一段常见的示例代码: while (1) { print "foo\n"; } 永远打印“foo”。 perl foo.pl foo foo foo ... 和 while (0) { p
我对 Haskell 比较陌生,来自 F#(一种 Microsoft 语言)。 我已经从脚手架创建了一个 Yesod 项目,稍微玩了一下,调整了一些东西,但随后它停止工作,并显示此错误消息(在所有模块
我是一名优秀的程序员,十分优秀!