2

NuGet 包管理器有问题。我发布了我的库(一个类型提供程序,但我认为这并不重要)然后测试它,但它找不到依赖项。完整的错误消息是(为简洁起见,省略了完整的命名空间/名称):

The type provider 'TypeProviderImplementation....' reported an error:
Could not load file or assembly 'dotNetRDF', Version=1.0.3.0, Culture=neutral, PublicKeyToken=...' or one of its dependencies.

问题是在安装库时,看起来依赖项已正确安装。下载了正确的库,并且没有出现错误。为了解决这个问题,我在 .nuspec 文件中指定了确切的版本,但这并没有改变任何东西。...

通过 NuGet 安装 dotNetRDF,然后手动引用我的预编译 DLL(不通过 NuGet)似乎工作正常。

所以我基本上不知道如何解决甚至调试问题。我很感谢任何指示。

添加有关 .NET 版本号的更多信息,因为我在下面的评论很难阅读:

我按照建议检查了框架版本。我通过查看对象浏览器中的 FrameworkDisplayName 来做到这一点。基本上,我的库使用的是 4.5,而 dotNetRDF 使用的是 4.0。

我切换到 .NET 4.0,但没有任何改变。

  • 我的库 =“.NET Framework 4”
  • dotNetRDF = ".NET 框架 4"
  • HtmlAgilityPack = ".NET 框架 4.5"
  • Newtonsoft.Json = ".NET 框架 4.5"
  • VDS.Common = ".NET Framework 4 客户端配置文件"

我的依赖是dotNetRDF,剩下的是dotNetRDF的依赖。

最新的 NuSpec 文件可以在这里找到。我通过命令nuget pack LITEQ.fsproj -Prop Configuration=Release创建包。

包 id 是LITEQ.RDF

一些附加信息: 该库是一个 F# 项目。我刚刚测试了如果我创建一个控制台项目并通过 NuGet 安装库然后将引用发送到 F# 交互式控制台会发生什么。它实际上在这种情况下有效。

所以感觉通过NuGet安装库后项目配置有问题。

要重现错误,请下载库,打开 UniKo.West.Liteq 命名空间,例如使用 NpqlTypeProvider:

open Uniko.West.Liteq

type A = NpqlRdfProvider< @"">
4

2 回答 2

0

一个临时的解决方案(或更多的破解)是不依赖依赖项,而是直接将 DLL 放入 NuGet 包中。当我这样做时,图书馆工作正常。本例中的 NuSpec 文件如下所示(摘录):

<package>
    <metadata>
        ...
    </metadata>
    <files>
        <file src="bin\Release\dotNetRDF.dll" target="lib/net40" />
        <file src="bin\Release\HtmlAgilityPack.dll" target="lib/net40" />
        <file src="bin\Release\HtmlAgilityPack.pdb" target="lib/net40" />
        <file src="bin\Release\HtmlAgilityPack.xml" target="lib/net40" />
        ...
    </files>
</package>

但显然,这不是一个好的解决方案。

于 2014-08-25T08:38:45.860 回答
0

当然,对我来说,我看不到任何明显的问题,当我将你的包安装到一个空的控制台项目中时,我没有任何问题,我可以编写一个使用 dotNetRDF API 的简单示例。如果您可以生成一个最小的示例项目,在该项目中安装软件包会产生问题,那么这将非常有帮助。

你的问题

但是,您为项目声明的依赖项看起来是错误的,您的项目有 .Net 4.0 和一些依赖项,但其他的 .Net 4.5 将不起作用。请注意,当您降级项目的目标框架时,NuGet 无法很好地应对这种情况,最好在任何时候更改目标框架版本时完全卸载并重新安装 NuGet 包。框架的新版本依赖于针对旧版本的依赖项是非常好的,因此您的 .Net 4.5 项目可以愉快地依赖 .Net 4.0 版本的 dotNetRDF。然而,相反的情况并非如此,这可能是您的问题的原因。

您有时可以判断是否是这种情况,因为 VS 可能会在解决方案资源管理器中的“参考”下突出显示不良依赖关系,并带有很少的警告图标(遗憾的是,它并不总是这样做)。即使不是这种情况,当您尝试构建时,如果您有不兼容的依赖项,您应该在输出窗口中看到如下输出,这也可能产生有关缺少命名空间的编译错误:

C:\Program Files (x86)\MSBuild\12.0\bin\Microsoft.Common.CurrentVersion.targets(1697,5):警告 MSB3274:无法解析主要参考“HtmlAgilityPack”,因为它是针对“.NETFramework”构建的,版本=v4.5" 框架。这是比当前目标框架“.NETFramework,Version=v4.0”更高的版本。

因此,我强烈建议您在更改项目的目标 .Net 框架时通过 NuGet 卸载所有包并重新安装它们。

其他问题

关于其他可能的问题,您使用的不是最新版本的 dotNetRDF 1.0.3,1.0.5 之前的版本存在与 Json.Net 的版本控制和框架配置文件交互相关的已知问题。如果您要安装的项目也依赖于 Json.Net,您可能会遇到版本冲突问题。请参阅CORE-405: Resolve Issues with Json.Net dependency了解有关此问题的一些讨论。

我建议您在编写此答案时还将您的依赖项升级到最新的 dotNetRDF 版本,即 1.0.6.3421,看看是否能解决您的问题。

编辑 - NuGet 包版本

NuGet 包版本不必与程序集版本相对应,因为 1.0.6.3421 确实具有 1.0.3.0 的程序集版本。这实际上不是我们的意图,而是我们构建过程中的一个缺陷,但这在这里并不重要。

看起来您的库是针对不同版本的 dotNetRDF 编译的,而不是 NuGet 为您安装的版本。但是,如果没有看到包的来源,就不可能进一步调试。

如果两种解决方案都不起作用怎么办?

如果这些都不能解决您的问题,那么您将需要提供一个重现问题的最小项目。

于 2014-08-19T17:24:45.650 回答