我用我的数字签名签署了文件,我如何从这个文件中读取这个签名?
签名是可信的 (Globalsign)。加密 RSA/SHA1。签名文件为.exe
最佳答案
首先,您需要指定要处理的证书类型。如果您正在谈论 CLI 程序集,那么您可能正在处理 StrongName 签名,这是完全不同的野兽,旨在防止 CLR 的全局程序集缓存中的名称冲突。
这听起来更像是您想阅读用于 native 和 CLI 应用程序的 Authenticode 签名。如果您想阅读证书本身,那么您需要了解 PE/COFF 规范,并为 PE(可移植可执行文件)文件格式实现解析器,这是 Windows NT 及其衍生产品使用的格式。如果您希望能够真正验证该证书,您需要调用 WinVerifyTrust function ,它将为您执行 Authenticode 验证。
当然,如果您只是想检查您的证书是否有效而不需要编写您自己的应用程序来执行此操作,您可以右键单击该文件并在 Windows 资源管理器中选择属性...,它应该会向您显示文件的签名状态。否则,您可以使用命令行实用程序 SigCheck .
关于c++ - 如何读取 C++ 中的嵌入式代码签名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11888358/