搜索后我尝试过的事情:

in Web.Config put a binding on the old version: <dependentAssembly> <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" /> <bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.1.0" /> </dependentAssembly> Edit my .csproj file to make sure there is only one Newtonsoft reference <Reference Include="Newtonsoft.Json, Version=6.0.0.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed, processorArchitecture=MSIL"> <HintPath>..\packages\Newtonsoft.Json.6.0.1\lib\net45\Newtonsoft.Json.dll</HintPath> <SpecificVersion>False</SpecificVersion> <Private>True</Private> </Reference> Search my computer for every Newtonsoft.Json.dll and delete every non 6.0.1 version and delete the contents of my temp folder Repair/Reinstall the package in nuget manager console

它成功构建,但在访问站点时得到错误。

EDIT

好吧,然后我尝试重新安装每个nuget包,它似乎已经添加了4.5版本的newtonsoft.json.dll,但我得到了同样的错误。我的项目的目标框架是。net 4.5.1,这里是我现在得到的堆栈跟踪:

Server Error in '/' Application. Could not load file or assembly Newtonsoft.Json or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040) Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. Exception Details: System.IO.FileLoadException: Could not load file or assembly Newtonsoft.Json or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040) Source Error: An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below. Assembly Load Trace: The following information can be helpful to determine why the assembly Newtonsoft.Json could not be loaded.

=== Pre-bind state information ===
LOG: DisplayName = Newtonsoft.Json
(Partial)
WRN: Partial binding information was supplied for an assembly:
WRN: Assembly Name: Newtonsoft.Json | Domain ID: 2
WRN: A partial bind occurs when only part of the assembly display name is provided.
WRN: This might result in the binder loading an incorrect assembly.
WRN: It is recommended to provide a fully specified textual identity for the assembly,
WRN: that consists of the simple name, version, culture, and public key token.
WRN: See whitepaper http://go.microsoft.com/fwlink/?LinkId=109270 for more information and common solutions to this issue.
LOG: Appbase = file:///c:/users/user/documents/visual studio 2013/Projects/foo/bar/
LOG: Initial PrivatePath = c:\users\user\documents\visual studio 2013\Projects\foo\bar\bin
Calling assembly : (Unknown).
 ===
LOG: This bind starts in default load context.
LOG: Using application configuration file: c:\users\user\documents\visual studio 2013\Projects\foo\bar\web.config
LOG: Using host configuration file: C:\Users\user\Documents\IISExpress\config\aspnet.config
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Policy not being applied to reference at this time (private, custom, partial, or location-based assembly bind).
LOG: Attempting download of new URL file:///C:/Users/user/AppData/Local/Temp/1/Temporary ASP.NET Files/root/48686d37/9d7a6572/Newtonsoft.Json.DLL.
LOG: Attempting download of new URL file:///C:/Users/user/AppData/Local/Temp/1/Temporary ASP.NET Files/root/48686d37/9d7a6572/Newtonsoft.Json/Newtonsoft.Json.DLL.
LOG: Attempting download of new URL file:///c:/users/user/documents/visual studio 2013/Projects/foo/bar/bin/Newtonsoft.Json.DLL.
LOG: Using application configuration file: c:\users\user\documents\visual studio 2013\Projects\foo\bar\web.config
LOG: Using host configuration file: C:\Users\user\Documents\IISExpress\config\aspnet.config
LOG: Using machine configuration file from C:\Windows\Microsoft.NET\Framework\v4.0.30319\config\machine.config.
LOG: Redirect found in application configuration file: 4.5.0.0 redirected to 6.0.1.0.
LOG: Post-policy reference: Newtonsoft.Json, Version=6.0.1.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed
LOG: Attempting download of new URL file:///C:/Users/user/AppData/Local/Temp/1/Temporary ASP.NET Files/root/48686d37/9d7a6572/Newtonsoft.Json.DLL.
LOG: Attempting download of new URL file:///C:/Users/user/AppData/Local/Temp/1/Temporary ASP.NET Files/root/48686d37/9d7a6572/Newtonsoft.Json/Newtonsoft.Json.DLL.
LOG: Attempting download of new URL file:///c:/users/user/documents/visual studio 2013/Projects/foo/bar/bin/Newtonsoft.Json.DLL.
WRN: Comparing the assembly name resulted in the mismatch: Major Version
ERR: Failed to complete setup of assembly (hr = 0x80131040). Probing terminated.

堆栈跟踪:

[FileLoadException: Could not load file or assembly 'Newtonsoft.Json' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)]

[FileLoadException: Could not load file or assembly 'Newtonsoft.Json, Version=6.0.1.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)]
       System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) +0
       System.Reflection.RuntimeAssembly.nLoad(AssemblyName fileName, String codeBase, Evidence assemblySecurity, RuntimeAssembly locationHint, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) +34
       System.Reflection.RuntimeAssembly.InternalLoadAssemblyName(AssemblyName assemblyRef, Evidence assemblySecurity, RuntimeAssembly reqAssembly, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean throwOnFileNotFound, Boolean forIntrospection, Boolean suppressSecurityChecks) +152
       System.Reflection.RuntimeAssembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, IntPtr pPrivHostBinder, Boolean forIntrospection) +77
       System.Reflection.RuntimeAssembly.InternalLoad(String assemblyString, Evidence assemblySecurity, StackCrawlMark& stackMark, Boolean forIntrospection) +16
       System.Reflection.Assembly.Load(String assemblyString) +28
       System.Web.Configuration.CompilationSection.LoadAssemblyHelper(String assemblyName, Boolean starDirective) +38

[ConfigurationErrorsException: Could not load file or assembly 'Newtonsoft.Json, Version=6.0.1.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)]
       System.Web.Configuration.CompilationSection.LoadAssemblyHelper(String assemblyName, Boolean starDirective) +752
       System.Web.Configuration.CompilationSection.LoadAllAssembliesFromAppDomainBinDirectory() +218
       System.Web.Configuration.CompilationSection.LoadAssembly(AssemblyInfo ai) +130
        System.Web.Compilation.BuildManager.GetReferencedAssemblies(CompilationSection compConfig) +170
       System.Web.Compilation.BuildManager.GetPreStartInitMethodsFromReferencedAssemblies() +91
       System.Web.Compilation.BuildManager.CallPreStartInitMethods(String preStartInitListPath, Boolean& isRefAssemblyLoaded) +285
       System.Web.Compilation.BuildManager.ExecutePreAppStart() +153
       System.Web.Hosting.HostingEnvironment.Initialize(ApplicationManager appManager, IApplicationHost appHost, IConfigMapPathFactory configMapPathFactory, HostingEnvironmentParameters hostingParameters, PolicyLevel policyLevel, Exception appDomainCreationException) +516

[HttpException (0x80004005): Could not load file or assembly 'Newtonsoft.Json, Version=6.0.1.0, Culture=neutral, PublicKeyToken=30ad4fe6b2a6aeed' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)]
       System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +9913572
       System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +101
       System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +254

Version Information: Microsoft .NET Framework Version:4.0.30319; ASP.NET Version:4.0.30319.18408

好了,我想现在可以用了。我删除了我机器上所有不是我能找到的最新版本的Newtonsoft.Json.dll,确保我在NuGet中有最新的版本,并构建它,并确保在bin文件夹中是最新的版本,我把更改留在网络上。Config和.csproj. conf文件现在我对另一个错误,所以它必须工作..


我有同样的错误消息,就像你提到的,这是由于不同版本的Newtonsoft.Json.dll被引用。

我的MVC解决方案中的一些项目使用了该dll版本4的NuGet包。

然后我添加了一个NuGet包(在我的例子中是Salesforce),它带来了Newtonsoft。Json版本6,将其作为一个项目的依赖项。这就是引发我问题的原因。

为了清理,我使用NuGet Package Manager中的Updates部分来更新Json(关闭工具菜单或解决方案右键单击)。Net包贯穿整个解决方案,因此所有项目都是相同的版本。

之后,我只是检查了应用程序配置文件,以确保任何绑定重定向行将到我所选择的版本如下。

<bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />

我用的是牛顿软件。Json v6.0.3,但这是我必须在我的Web中做的。配置文件:

<dependentAssembly>
        <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
        <bindingRedirect oldVersion="0.0.0.0-4.5.0.0" newVersion="6.0.0.0" />
</dependentAssembly>

注意,即使我使用的是6.0.3,我必须在newVersion="6.0.0.0"

在我的包裹里。配置文件:

<package id="Newtonsoft.Json" version="6.0.3" targetFramework="net45" />

如果你在搞颠覆: 删除项目并重新下载,它为我工作:S


为了解决这个问题,我通过运行以下命令并检查结果来确保我所有的项目都使用了相同的版本:

update-package Newtonsoft.Json -reinstall

最后,我从我的web.config删除了以下内容:

  <dependentAssembly>
    <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
    <bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />
  </dependentAssembly>

如果你想确保所有的牛顿软。Json包是相同的版本,你可以这样指定版本:

update-package Newtonsoft.Json -version 6.0.0 -reinstall

注意:要在Visual Studio中打开PMC,请单击工具-> Nuget包管理器->包管理器控制台。谢谢@Rose !


在确保我的计算机在所有位置都有相同的版本并且我的项目都指向相同的参考路径之后,我尝试了以下操作。我还确保旧版本的绑定是他们的,并绑定到我拥有的当前版本的dll。

我在一个有严格框架的环境中工作,框架团队经常用不同的dll来打乱版本控制。

我解决这个问题的方法是在visual studio(2013)中运行包管理器控制台。从那里我运行以下命令:

update-package Newtonsoft.Json -reinstall

紧随其后的是

update-package Newtonsoft.Json

这遍历并更新了我所有的配置文件和相关的项目文件。强制它们都到同一个dll版本。它最初是4.5版本,然后再次更新以获得最新版本。


我在一个参考MVC 5项目的测试项目中遇到了同样的问题。这发生在我与一个MVC 5项目合并之后。我通过安装Visual studio 2012更新来解决这个问题,这在Andre的回复中有解释。

在你的视觉工作室转到 工具>扩展和更新 在左侧的手风琴列表中选择“Updates”。 选择“产品更新”。 更新到最新版本


简单的步骤。 (1)运行“update-package Newtonsoft”。在包管理器中重新安装。

(2)通过开启查看隐藏文件和删除bin文件夹来删除you bin。

(3)关闭你的视觉工作室并重新打开。

现在再次运行您的项目。 我相信应该没问题


我遇到了这个问题,因为我有:项目A(一个桌面。exe)引用项目B(一个便携式。dll)。A和B有不同版本的JSON。Net,所以有一个加载器冲突。 一旦我让所有版本的JSON.net都一样,它就工作了。(这实际上是上面的一些解决方案正在做的事情-我只是呼吁为什么它有效)


我最近在一个较老的项目中挣扎。

在检查bin文件夹中实际存在的dll版本后,我设法追踪到这个问题。

我有一个后期构建脚本,它将依赖程序集从dll库文件夹复制到bin文件夹。这是nuget之前常见的设置。

所以每次构建后构建脚本时,我都会用旧版本替换正确的Json.net版本


没有一个答案,包括选中的那个都不适合我。

解决办法要简单得多。我首先从BUS层删除了引用。然后从项目中删除dll(以确保它已经消失),然后重新安装JSON。NET从nuget包。而且,棘手的部分是,“把它关掉再打开”。

我刚刚重启visual studio,它工作了!

因此,如果您尝试了所有可能的方法,但仍然不能解决问题,请尝试关闭visual studio并再次打开,这可能会有所帮助。


对我来说,这只是一个问题:

Tools -> NuGet Package Manager -> Package Manager Settings -> Clear Cache

这个问题是在我重新映射TFS文件夹时引起的。


我有完全相同的问题和Visual Studio 13默认库为我是4.5,所以我有2个解决方案,一个是拿出这个在webconfig文件中的引用。这是最后的手段,而且确实有效。

错误信息指出此位置/Projects/foo/bar/bin/Newtonsoft.Json.DLL有问题。DLL在哪里!一个基本的属性检查告诉我它是4.5.0.0或类似的,所以我把webconfig修改为4.5并使用4.5。


这些选择都不适合我,但最终我还是选择了。

测试>测试设置> *.testrunconfig . Test

我得加一行

<DeploymentItem filename="packages\Newtonsoft.Json.4.5.8\lib\net40\Newtonsoft.Json.dll" />

确保路径和版本适合您的设置。


我不知道为什么,但在我的情况下,即使我从项目中删除bin文件夹,当我构建项目时,它会复制旧版本的newtonsoft。json,我复制了新版本的dll从包文件夹和它解决现在。


如果这些都不行,请检查这个答案:

https://stackoverflow.com/a/12011221/150370

(TL;DR:从配置文件中的配置标签中删除xml命名空间。否则绑定重定向将被忽略)


我也有同样的问题。我创建了一个web api项目,然后将它从。net 4.5.1升级到。net 4.6.1。关闭IDE,停止IIS,删除C:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP. net文件中的内容。NET Files\ dir修复了这个问题。

HTH


在某些情况下,如果你删除Bin和Obj文件夹就可以解决这个问题。


这个问题并没有通过刷新NuGet包或在项目上执行“清洁”来解决。这个问题是通过手动清除“obj”文件夹解决的。


我尝试过奥列格的步骤,他们对我同样的情况起作用。

步骤:

运行update-package Newtonsoft。在包管理器中重新安装。 通过启用查看隐藏文件和删除bin文件夹来删除您的bin。 关闭Visual Studio并重新打开它。 现在再次运行您的项目。我相信应该没问题!


我通过在bin文件夹中删除低版本的Newtonsoft.json.dll来解决这个问题,并添加了Newtonsoft.json.dll V6.0.0.0并删除了以下web。配置元素

<dependentAssembly>
    <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed"/>
    <bindingRedirect oldVersion="0.0.0.0-4.5.0.0" newVersion="5.0.8"/>
</dependentAssembly>

以下是我对这个问题的解决方案,请确保appconfig或packageconfig中的版本号与参考文档中的参考版本相同。 在这里看到的


在我的网页上把这部分注释掉。Config解决了我的问题:

<dependentAssembly>
    <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
    <bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />
</dependentAssembly>

但是当然,你需要确保你已经更新或你有正确的版本,在你的包管理器控制台中这样做:

update-package Newtonsoft.Json -reinstall

您可以通过在web中添加以下行来解决这个问题。配置文件。

 <runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral"/>
        <bindingRedirect oldVersion="0.0.0.0-8.0.0.0" newVersion="8.0.0.0"/>
      </dependentAssembly>
    </assemblyBinding>
  </runtime>

真正帮助我的是关闭Resharper构建,并在我的项目中使用VisualStudio Re-Build选项。


我得到了dotnet核心同样的问题,并设法通过清除NuGet缓存来修复它。

打开powershell,输入以下命令。

dotnet nuget locals all --clear

然后我关闭Visual Studio,再次打开它,并在包管理器控制台输入以下命令:

Update-Package

NuGet现在应该恢复所有的包,并再次填充NuGet缓存。

在那之后,我能够在Linux容器中构建并启动我的dotnet核心webapi。


在我的情况下,在错误消息是“版本6.0.0”,但这个版本是不可安装的,所以我安装了“6.0.1版本”在我的项目,并解决了我的问题。

install-package Newtonsoft.Json -Version 6.0.1 -Project MyProjectX

从工具>>NuGet包管理>>管理包解决方案 更新Newtonsoft。最新版本的所有解决方案的Json


我的问题是newVersion在这段代码在web。配置不正确

<dependentAssembly>
    <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.1.0" />

你可以看到Newtonsoft的版本。在nuget包管理器中使用Json包。


解决我这个问题的办法是

goto引用->右键单击Newtonsoft。goto属性,检查版本

同样的版本应该在

<dependentAssembly>
    <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
    <bindingRedirect oldVersion="0.0.0.0-YourDllVersion" newVersion="YourDllVersion" />
</dependentAssembly>

好吧,所以我想要做的事情是把我的答案添加到这个长列表中,而不是创建一个重复的问题……

如果你在2019年使用。net Core 3.0(目前是预览版),解决方案是确保所有项目都针对相同的。net Core版本(在我的情况下是3.0)。我想我在解决方案中有一个项目是针对2.1的,其余的是2.2的,所以我可能会坚持使用2.2…

我甚至没有牛顿软体。Json安装在任何项目中,自然地添加它并不能解决这个问题。

如果你的解决方案中有。net标准类库或w/e,它们不需要在同一个版本上,尽管它们可能应该是你可以使用的最新版本。例如,我的. net标准类库是在2.2上的,因为还没有. net标准3.0。


经过几个小时的挣扎…我做了以下事情:

. config

<runtime>

  <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">

    <dependentAssembly>
      <assemblyIdentity name="Newtonsoft.Json" publicKeyToken="30ad4fe6b2a6aeed" culture="neutral" />
      <bindingRedirect oldVersion="0.0.0.0-12.0.0.0" newVersion="12.0.0.0" />
    </dependentAssembly>

    <!-- other assemblies... -->

  </assemblyBinding>
</runtime>

输入正确的newVersion和oldVersion编号的关键是打开项目的引用,找到包,进入它的属性或单击alt + enter

你会发现一节版本,在我的情况下是12.0.0.0,而它实际上是12.0.3,当探索与管理NuGet。

所以您需要从引用属性中选择包的版本(在我的例子中是12.0.0.0)

最后,清理并重新构建项目(您可能希望之前删除bin和obj文件夹)。

你可能会面临其他包的依赖问题,我做的所有,他们工作。


请注意,我有这个问题与桌面应用程序开发,而不是在WEB应用程序开发。 我在寻找解决方案时被重定向到这里,如果你也被重定向到这里,那么你可以使用GAC(全局程序集缓存),它用于将通用dll存储到全局以供使用。

我在医院的问题: 假设,我从C:\Documents通过CMD运行应用程序,并给定完整应用程序的路径D:\MyApp\MyApp.exe,其中使用Newtonsoft.json.dll和MyDLL.dll分别进行json和处理,它们存储在位置D:\MyApp\文件夹中。 现在,在执行时,它开始在C:\Users\Public中搜索DLL,其中没有DLL。然后,它给出错误,无法加载DLL Newtonsoft.json.dll。

所以我最终在GAC注册了dll。 可以通过两种方式安装

使用GACUTIL 您可以在“如何在GAC中注册.NET DLL文件”中找到步骤。

它很简单,但与Visual Studio安装一起安装。

如果GACUTIL不可用,请使用POWERSHELL

你可以关注Link, https://asvignesh.in/register-dll-in-gac-without-using-gacutil/

或使用哪个(链接页面描述与下方描述相同) Powershell命令:

PS C:\WINDOWS\system32> [System. reflection . assembly]::Load("System. reflection . assembly ")EnterpriseServices, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a")

PS C:\WINDOWS\system32> $publish = New-Object System.EnterpriseServices.Internal.Publish PS C:\WINDOWS\system32> $publish。GacInstall("dll path full");

希望你能找到答案。


对我有帮助的是将NuGet升级到最新版本。希望这能有所帮助。


安装或更新Newtonsoft后,web会发生一些变化。配置和那些必须移动到网络。在live/prod环境中,它们是必需的,这取决于使用的版本。

我们也有同样的问题,因为我们一直在使用发布自动化和wen。配置文件将不会在prod/staging环境中被覆盖。所以web必须手动更改配置文件。


特别是对于IIS上下文:

我想提到另一个我在其他答案中没有看到的角度。如果您在IIS中看到此错误,有时它会莫名其妙地在其临时目录中保留dll以前版本的缓存副本。如果您已经检查了/bin目录下DLL的版本,并且已经检查了web中的绑定重定向。配置,IIS只是似乎没有“看到”本地(正确版本)副本的DLL,这里有步骤得到它的底部:

Follow the instructions in this answer to turn on assembly bind logging (there is a performance penalty, so remember to turn this off when you're done); Get the assembly bind log viewer (FUSLOGVW.exe, in the VS SDK, or available from Microsoft); Make a request to the site, review the log list to find the binding that's failing In the log contents, you can see every candidate DLL considered to satisfy a binding request. If you have verified that the copy in your bin directory is correct, inspect the others and remove them if necessary: