views:

29

answers:

2

I have 2 dlls. One dll is refering to the another one. I checked the mainfest of first dll and found it is referncing to the 2nd one with some specific token key.

But I checked the token of second assembly and found that it has some diffrent public token. So somehow I missed the correct 2 second assembly. So I want to know is there a way I can make the second assembly's public token to the one which first assembly needs.

Also I have another second dll also which has public token = null.

A: 

You are asking "how can I forge second assembly's signature to make first assembly think it's original". Unless you have a keypair, used to sign the "right" assembly, you can't. So the best approach is to ask the vendor of the assemblies to provide a correct pair.

Eugene Mayevski 'EldoS Corp
if a know the public token then also it is not possible?
Nits
Read about asymmetric cryptography and how signing works. You can sign only using private key. Public key is used for verification (you can't sign using public key).
Eugene Mayevski 'EldoS Corp
+1  A: 

Sounds like you want to rebuild the second assembly and sign it with a different key, which would be easy if you had the source so I guess you don't?

I think it would be easier to rebuild the first assembly so that it references the second assembly you have, using the public key token that is present on the second assembly. Easier, but not entirely straightforward.

I think you should be able to achieve it by running the first assembly through ildasm.exe, change the public key token on the reference to the second assembly, and then run the result through ilasm.exe, to produce a new version of the first assembly.

A rough outline of the steps involved...

  1. Run ildasm.exe /out=first.il first.dll (or first.exe)
  2. Edit first.il and find the .assembly extern block for the reference to second.dll
  3. Change the public key token in that block
  4. Run ilasm.exe first.il to produce first.dll (or first.exe)

Be warned, I haven't used these tools for a long time, and never to manipulate public key tokens in this way, so you will probably have to add some ingenuity of your own. But on the other hand, I can't think of a reason for this approach not to work.

Martin
can you please direct me how to do that?
Nits
added more detail.
Martin