验证pe文件数字签名

这个C++程序演示了如何使用Windows API检查PE文件的数字签名。通过调用WinVerifyTrust和相关函数,它能验证文件的可信性,并返回验证结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// exam5.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <tchar.h>
#include <Windows.h>
#include <WinTrust.h>
#include <SoftPub.h>
#include "mscat.h"

#pragma comment (lib, "WinTrust.lib")
BOOL CheckFileTrust(LPCTSTR lpFileName);

BOOL CheckFileTrust(LPCTSTR lpFileName)
{
	BOOL bRet = FALSE;
	WINTRUST_DATA wd = { 0 };
	WINTRUST_FILE_INFO wfi = { 0 };
	WINTRUST_CATALOG_INFO wci = { 0 };
	CATALOG_INFO ci	= { 0 };

	HCATADMIN hCatAdmin	= NULL;
	if (!CryptCATAdminAcquireContext(&hCatAdmin, NULL, 0))
	{
		return FALSE;
	}

	HANDLE hFile = CreateFile(lpFileName, 
					GENERIC_READ, 
					FILE_SHARE_READ,
					NULL, OPEN_EXISTING, 
					0, NULL );
	if (INVALID_HANDLE_VALUE == hFile)
	{
		CryptCATAdminReleaseContext(hCatAdmin, 0);
		return FALSE;
	}

	DWORD dwCnt = 100;
	BYTE byHash[100] = { 0 };
	CryptCATAdminCalcHashFromFileHandle(hFile, &dwCnt, byHash, 0)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值