Reputation: 411
I'm getting the following exception when trying to call GetDatabase
method of the MongoClient
class after adding a new configuration using VS config. manager:
Could not load file or assembly 'System.Buffers, Version=4.0.2.0, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51' or one of its dependencies. The located assembly's manifest definition does not match the assembly reference. (Exception from HRESULT: 0x80131040)
I installed the latest System.Buffer nuget package v4.5.1, created dependentAssembly in my app.config and Reference in my .csproj file, but I still have the same issue. For some reason, it tries to reference System.Buffer with v4.0.2. Has anyone had a similar error and how did you solve it?
Upvotes: 29
Views: 52294
Reputation: 51
I ran into this issue when adding the Azure.Storage.Blobs
package to a Class Library where I was attempting to create a blob uploader client. When I added the package, it created an app.config
with the correct binding redirect:
<dependentAssembly>
<assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.0.3.0" newVersion="4.0.3.0" />
</dependentAssembly>
<dependentAssembly>
The issue, however, is that this binding redirect needs to live in the app.config
of the application, not the class library: Can a class library have an App.config file?
So, adding the binding redirect is the correct way to solve this issue. Just make sure the binding redirect is specified in the calling web/console/etc app.
Upvotes: 5
Reputation: 11
In my case, the answer was that the dependencies were in a DLL, but the EXE referencing the DLL needed to also contain the assembly bindings in the runtime section of the app.config:
<dependentAssembly>
<assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.0.3.0" newVersion="4.0.3.0" />
</dependentAssembly>
Rebuilding the app then resolved the issue for me. VS2017 C# Winforms app .NET frameworks 4.6.1.
Upvotes: 1
Reputation: 153
In my case, I had to add the assembly reference in the web.config that was already published in the Azure App Service, inside the <configuration></configuration>
tag:
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="System.Buffers" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.0.3.0" newVersion="4.0.3.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
Upvotes: 10
Reputation: 1
We are experiencing problems with the accepted solution. Our software (32 bit .NET Framework) ships System.Buffers (.NET 4.6.1) with it and we haven't had any problems resolving it that way.
We think this is actually a proper solution to the issue, but of course requires distributing/installing the software again.
However, we now experience crashes with our software on machines were System.Buffers.dll (netstandard1.1) is located in GAC. Since GAC is preferred (here) and the GAC dll is loaded instead of the one we ship, we then later get a problem resolving System.Threading.dll and System.Runtime.dll (both in GAC installed by .NET Framework).
Removing the dll from GAC solves our problem, but obvious might break whoever placed the dll in GAC.
Examining the Fusion log we see that System.Runtime.dll was not found (despite being in GAC) and it was needed by System.Buffers.dll.
To our surprise we saw that System.Buffers.dll is loaded from GAC, even if we ship it in the installation.
We were also able to reproduce the issue by placing the .NETStandard 1.1 version of System.Buffers in GAC:
Workarounds/solutions:
Upvotes: 0
Reputation: 120
Just install NuGet Package 4.4.0 and deploy depending Assembly ( System.Buffers ) to Gac.
Upvotes: 0
Reputation: 1
I ran into a similar issue, tried all the steps above. In the end, another project had an older version of the same library. Too many projects in the solution, the other reference was scrolled out of view.
Upvotes: -1
Reputation: 4208
Another solution: just remove references to the assembly in the Web.config
files of the projects generating the exception.
The references can look like:
<dependentAssembly>
<assemblyIdentity name="System.Text.Encodings.Web" publicKeyToken="cc7b13ffcd2ddd51" culture="neutral" />
<bindingRedirect oldVersion="0.0.0.0-4.0.4.0" newVersion="4.0.4.0" />
</dependentAssembly>
Upvotes: 0
Reputation: 734
The easiest way is to use Nuget package manager, downgrade system.buffers to any lower version, and then upgrade it to the latest again.
Upvotes: 3
Reputation: 23818
Could not load file or assembly 'System.Buffers, Version=4.0.2.0…'
Solution
1) use CMD(run as Administrator ) and type
cd xxxx(xxxx\packages\System.Buffers.4.5.1\lib\netstandard2.0))
run
gacutil /i System.Buffers.dll
Then, when you finish it, please run update-package -reinstall
under package manager console
to reinstall the package.
2) you can try to change Version=4.0.2.0
to Version=4.0.3.0
in csproj file.
Besides, there is a similar issue you can refer to.
Upvotes: 10