无法解决程序集引用 – dependentAssembly问题?

我的构建服务器(TFS / Visual Studio Online)上发生以下错误:

CA0055 : Could not load C:\a\Binaries\Api.dll. The following error was encountered while reading module 'System.Net.Http.Formatting': Assembly reference cannot be resolved: Newtonsoft.Json, Version=4.5.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed. CA0058 : The referenced assembly 'Newtonsoft.Json, Version=4.5.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed' could not be found. This assembly is required for analysis and was referenced by: C:\a\Binaries\Api.dll, C:\a\Sources\MyLocation\packages\Microsoft.AspNet.WebApi.Client.5.1.1\lib\net45\System.Net.Http.Formatting.dll. 

以下是此程序集的Api.dll项目中的web.config dependentAssembly条目:

     

已安装的Json.NET NuGet包的实际版本是6.0.1:

在此处输入图像描述

在查看项目引用时,我将Newtonsoft.Json作为6.0.0.0:

在此处输入图像描述

引用中System.Net.Http.Formatting的版本是5.1.0.0。

在构建定义中启用了NuGet还原,并且我的本地副本上没有这些错误,仅在TFS中。

有人能够发现可能出现的问题吗?

我认为这可能是由于dependentAssembly条目,但我无法让它工作。

如果您已经清理了项目文件,包文件和引用,并且所有版本都是Newtonsoft的正确和最新版本,它可能是一个依赖于早期版本的Newtonsoft.Json的.Net dll。 在我的例子中,它是System.Net.Http.Formatting,版本= 4.0.0.0:

在此处输入图像描述

尝试将以下内容添加到调用项目的* .config中:

     

当针对WebAPI项目运行测试项目时,由于Newtonsoft.Json版本在4.5.0.0和6.0.1.0之间不匹配,因此从WebAPI抛出了FileNotFoundexception。 将语句添加到调用测试项目的app.config修复了该问题。

这个问题出人意料。

修复是在每个相关的部分下的项目文件中包含以下行:

 /assemblyCompareMode:StrongNameIgnoringVersion 

要编辑项目文件,请右键单击该项目,然后单击“ 卸载项目” 。 现在右键单击卸载的项目,然后选择Edit MyProject.csproj

在我的情况下,Newtonsoft.Json bindingredirect无法正常工作,因为root web.config文件不是部署文件的一部分。

检查web.config文件的属性。 我的情况是,“Build Action”值设置为“None”。 应将其设置为“Content”,使其成为服务器部署文件的一部分。

还解释了为什么该网站正在(本地)IISexpress上工作,但没有在完整的IIS实例上工作。