c# 签名和延迟签名
产品化的工程一般都需要签名,以防伪造:
正常签名过程:
1. 启用
2. 生成key file
3. 键入密码然后生成
4. 使用
5. 测试工程加载并使用
延迟签名
1. 生成公钥和私钥
sn -k private.snk
sn -p private.snk public.snk
2.工程使用公钥编译
编译成功后,一般是放到服务器上再用私钥再次签名。
假如现在立即加载这个dll,就会抛出异常
3. 使用命令把私钥也签进去
sn -R MyTestLibrary.dll private.snk
现在签名的过程才算结束了,现在再尝试去加载这个dll,就不会抛出异常
之前的异常信息:
System.IO.FileLoadException: 'Could not load file or assembly 'MyTestLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=4e52d97effcdb02e' or one of its dependencies. Strong name validation failed. (Exception from HRESULT: 0x8013141A)'
以后看到这个错误信息,应该立即能知道这个dll还没有被完整签名,所以不能被正常加载。