0

0

C#怎么给程序添加数字签名_C#如何验证exe文件的合法性【方法】

穿越時空

穿越時空

发布时间:2026-03-17 03:57:25

|

303人浏览过

|

来源于php中文网

原创

使用signtool.exe为.exe文件签名需先将含私钥的PFX证书导入当前用户个人存储,再执行signtool sign /f "cert.pfx" /p "password" /t "http://timestamp.digicert.com" MyApp.exe;签名后用signtool verify /pa验证,并调WinVerifyTrust确保可信。

怎么用 signtool.exe 给 .exe 文件加数字签名

签名不是 c# 代码里写的,而是构建完成后用 windows sdk 提供的 signtool.exe 工具操作。你得先有 pfx 证书文件(含私钥),且密码已知。

常见错误现象:SignTool Error: No certificates were found that met all the given criteria——多半是证书没导入到当前用户个人证书存储,或 PFX 密码错/证书过期/没启用代码签名用途。

  • 确保 PFX 用 certutil -dump your.pfx 能正常读出,并看到 Enhanced Key Usage: Code Signing
  • 命令示例:signtool sign /f "cert.pfx" /p "password" /t "http://timestamp.digicert.com" MyApp.exe/t 时间戳服务器必须加,否则签名随证书过期失效
  • 如果用 CI/CD(如 GitHub Actions),注意 signtool 需要 Windows 运行时 + Windows SDK,Linux/macOS 上直接跑不了
  • 签名后可用 signtool verify /pa MyApp.exe 快速检查是否签成功(/pa 表示使用 Authenticode 策略验证)

C# 里怎么验证一个 EXE 文件有没有有效签名

不能只看“是否有签名”,得验证签名链可信、未被篡改、且时间在证书有效期内。.NET 没封装完整验证逻辑,得调 Win32 API WinVerifyTrust 或用 System.Security.Cryptography.X509Certificates 手动解析,但后者不校验签名有效性。

最稳的方式是调 WinVerifyTrust,封装成简单方法:

static bool IsSignedAndTrusted(string filePath)
{
    var hFile = CreateFile(filePath, FileAccess.Read, FileShare.Read, IntPtr.Zero, FileMode.Open, 0, IntPtr.Zero);
    if (hFile == IntPtr.Zero) return false;
<pre class='brush:php;toolbar:false;'>var policyGUID = new Guid("a848b716-45e7-488e-b48c-61e03d8d8c61"); // WINTRUST_ACTION_GENERIC_VERIFY_V2
var data = new WINTRUST_DATA { ... }; // 结构体需完整定义(略)
var result = WinVerifyTrust(IntPtr.Zero, ref policyGUID, ref data);

CloseHandle(hFile);
return result == 0;

}

容易踩的坑:WinVerifyTrust 返回 0 表示可信,不是“成功”;返回 0x800b0101(CERT_E_EXPIRED)或 0x800b0109(CERT_E_UNTRUSTEDROOT)说明验证失败,但程序不会抛异常,得自己查错误码。

Deep Search
Deep Search

智能文献、网页检索与分析工具。AI赋能,洞悉万象,让知识检索与总结触手可及

下载
  • 别用 Assembly.GetExecutingAssembly().GetName().GetPublicKey() 判断——它只读强名称,和 Authenticode 签名完全无关
  • 验证前确保目标文件没被锁定(比如正在运行),否则 CreateFile 失败
  • 若在沙盒环境(如 ClickOnce 或某些杀软拦截下),WinVerifyTrust 可能返回 0x80096010(TRUST_E_NOSIGNATURE),不是证书问题,是访问受限

为什么签名了还是被 Windows SmartScreen 拦截

签名只是第一步,SmartScreen 看的是“这个发布者是否被用户/系统信任”,核心是声誉积累,不是技术动作做完就自动放行。

典型现象:新证书签名的 EXE 第一次下载,提示“未知发布者”,点“更多信息”→“仍要运行”,之后才可能逐步降低警告级别。

  • 单次签名无法绕过 SmartScreen,哪怕用了 DigiCert/OV 证书也一样;EV 证书能跳过首次警告,但需硬件令牌+人工审核,成本高
  • 分发渠道影响极大:从你自己的 HTTPS 域名下载,比从百度网盘/邮件附件下载更容易建立信誉
  • 文件名别带“crack”“patch”“keygen”等敏感词,SmartScreen 会直接关联恶意行为模式
  • 提交到 Microsoft SmartScreen Submission Portal(https://smartscreen.microsoft.com)可加速信誉收录,但需提供公司信息和文件哈希

签名相关路径和配置项容易填错的地方

路径和参数名看着简单,拼错一个字符就失败,而且错误提示往往不明确。

  • signtool.exe 路径常在 C:\Program Files (x86)\Windows Kits\10\bin\<ver>\x64\signtool.exe,不同 SDK 版本号(如 10.0.22621.0)要核对清楚,别用旧版去签 Win11 兼容文件
  • 时间戳 URL 必须用 HTTP(不是 HTTPS),且服务要在线;http://timestamp.digicert.comhttp://timestamp.sectigo.com 是目前较稳的两个
  • PFX 文件路径含空格必须用英文双引号包裹,但密码参数 /p 后面的值**不能加引号**,否则当成带引号的密码处理
  • 验证时用的 WINTRUST_DATA 结构里,dwUIChoice 设成 WTD_UI_NONE,否则弹窗打断自动化流程

真正卡住人的,往往是证书导出时没勾选“导出私钥”,或者 PFX 密码输错三次导致 Windows 证书存储锁死——这时候重装证书都无效,得进 certmgr.msc 手动删掉冲突项再重导。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

513

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

384

2023.10.25

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

4511

2026.01.21

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1541

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1172

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

837

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

463

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2362

2023.08.08

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.4万人学习

C 教程
C 教程

共75课时 | 5.5万人学习

C++教程
C++教程

共115课时 | 22.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号