.Net Assembly Binding Redirect with Differing Public Key Tokens

.Netasp.netAssemblybindingPublickeytoken

.Net Problem Overview


Is it possible to perform an assembly binding redirect between different versions of a referenced assembly if the public key token is null on the older version and set on the newer version?

For example, I have two assemblies...

System.Web.Mvc, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null

and

System.Web.Mvc, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35

Should the following assembly binding redirect work in the Asp.Net web.config...

<runtime>
  <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
    <dependentAssembly>
      <assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35"/>
      <bindingRedirect oldVersion="1.0.0.0" newVersion="2.0.0.0"/>
    </dependentAssembly>
  </assemblyBinding>
</runtime>

.Net Solutions


Solution 1 - .Net

No, it is not possible. The assemblies need to have the same publicKeyToken.

The bindingRedirect tag only has the oldVersion and newVersion attributes, so there's no way to tell it about the "null" version anyway.

But the real reason behind is explained due to the strong name mechanism

Solution 2 - .Net

You might be able to use the AppDomain.AssemblyResolve event to do that. I've included some sample code in this answer.

Solution 3 - .Net

It does seem that a binding-redirect can't be used, but in my case I did manage to get around the problem with differing publicKeyTokens by amending the token-value being requested in the referencing DLL:

Disassemble the dll to IL, change reference, reassemble (and re-sign - which might be an issue if you don't have the keyfile).

(See my comment on https://stackoverflow.com/questions/12346293/when-referencing-assemblies-is-it-possible-to-insist-on-a-version-number-but-ig )

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionRussell GiddingsView Question on Stackoverflow
Solution 1 - .NetMark WorthView Answer on Stackoverflow
Solution 2 - .NetDon KirkbyView Answer on Stackoverflow
Solution 3 - .NetmwardmView Answer on Stackoverflow