To sign assembly A, you must make sure that all assemblies B, C, D that are used by A are signed, and then all assemblies that are used by B, C, D, etc. I don’t understand what kind of security it is. I think this should prevent fake, but assembly A is allowed to open any file, and it can be faked. The same goes for the external web server.
Also, it's too easy to sign the assembly with the .snk file that you publish bypassing this requirement.
source
share