⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 decryptfile.cpp

📁 PKCS#11 读取USB KEY证书
💻 CPP
字号:
#include <cstdio>
#include <iostream>
#include <string>
#include <vector>
using namespace std;

#include "generic.h"

bool DecryptFile(const string &strSource,
		const string &strDestination,
		const string &strPassword); 

void main(void)
{
	char szSrcFile[1024] = {0};
	char szTgtFile[1024] = {0};
	char szPassword[1024] = {0};

	printf("\nDecrypt a file.\n\nEnter the name of the file to be decrypt:\n");
	scanf("%s", szSrcFile);

	printf("Enter the name of the output file:\n");
	scanf("%s", szTgtFile);

	printf("Enter the password to encrypt the file:\n");
	scanf("%s", szPassword);

	if(DecryptFile(szSrcFile, szTgtFile, szPassword))
	{
		printf("Decrypt file successfully.\n");
	}
	else
	{
		printf("Decrypt file failed.\n");
	}
} // End of main

//--------------------------------------------------------------------
//    Define the function Decryptfile.

bool DecryptFile(const string &strSource,
		const string &strDestination,
		const string &strPassword)
{
	FILE *hSource = NULL; 
	FILE *hDestination = NULL;

	//--------------------------------------------------------------------
	// Open source file. 
	BeginAction("Open source file for read");
	if(NULL != (hSource = fopen(strSource.c_str(), "rb")))
	{
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}

	//--------------------------------------------------------------------
	// Open destination file. 
	BeginAction("Open target file for write");
	if(NULL != (hDestination = fopen(strDestination.c_str(), "wb")))
	{
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}

	HCRYPTPROV hCryptProv = NULL;
	HCRYPTKEY hKey = NULL;
	HCRYPTHASH hHash = NULL;

	//--------------------------------------------------------------------
	// Get a handle to the provider. 
	BeginAction("CryptAcquireContext()");
	if(CryptAcquireContext(&hCryptProv,
			TEST_CONTAINER,
			CSP_NAME,   //epassNG CSP
			PROV_RSA_FULL,
			0))
	{
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}

	HCRYPTPROV_Holder holder(hCryptProv);

	//--------------------------------------------------------------------
	// Create a hash object. 
	BeginAction("CryptCreateHash()");
	if(CryptCreateHash(hCryptProv, CALG_MD5, 0, 0, &hHash))
	{
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}  
	//--------------------------------------------------------------------
	// Hash in the password data. 

	BeginAction("CryptHashData()");
	if(CryptHashData(hHash,
			(BYTE *) strPassword.c_str(),
			strPassword.length(),
			0))
	{
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}

	//--------------------------------------------------------------------
	// Derive a session key from the hash object. 
	BeginAction("CryptDeriveKey()");
	if(CryptDeriveKey(hCryptProv, ENCRYPT_ALGORITHM, hHash, KEYLENGTH, &hKey))
	{
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}

	//--------------------------------------------------------------------
	// Destroy the hash object. 
	BeginAction("CryptDestroyHash()");
	if(CryptDestroyHash(hHash))
	{
		hHash = NULL; 
		ActionSuccess();
	}
	else
	{
		ActionFailed(GetLastError());
		return FALSE;
	}

	//--------------------------------------------------------------------
	//   The decryption key is now available, either having been imported
	//   from a BLOB read in from the source file or having been created 
	//   using the password. This point in the program is not reached if 
	//   the decryption key is not available.

	//--------------------------------------------------------------------
	// Determine the number of bytes to decrypt at a time. 
	// This must be a multiple of ENCRYPT_BLOCK_SIZE. 

	DWORD dwBlockLen = 0;
	DWORD dwBufferLen = 0;
	DWORD dwCount = 0;

	dwBlockLen = 1000 - 1000 % ENCRYPT_BLOCK_SIZE; 
	dwBufferLen = dwBlockLen; 

	vector<BYTE> pbBuffer;
	pbBuffer.resize(dwBufferLen);

	//--------------------------------------------------------------------
	// Decrypt source file, and write to destination file. 

	do
	{
		//--------------------------------------------------------------------
		// Read up to dwBlockLen bytes from source file. 
		dwCount = fread(&pbBuffer[0], 1, dwBlockLen, hSource); 
		if(ferror(hSource))
		{
			ShowSysError("Read cipher text", GetLastError());
			return FALSE;
		}

		//--------------------------------------------------------------------
		// Decrypt data. 
		if(!CryptDecrypt(hKey, 0, feof(hSource), 0, &pbBuffer[0], &dwCount))
		{
			ShowSysError("CryptDecrypt()", GetLastError());
			return FALSE;
		}

		//--------------------------------------------------------------------
		// Write data to destination file. 
		fwrite(&pbBuffer[0], 1, dwCount, hDestination); 
		if(ferror(hDestination))
		{
			ShowSysError("Write plain text", GetLastError());
			return FALSE;
		}
	}
	while(!feof(hSource)); 

	//--------------------------------------------------------------------
	// Close files. 
	if(hSource)
	{
		fclose(hSource);
	} 
	if(hDestination)
	{
		fclose(hDestination);
	} 

	//--------------------------------------------------------------------
	// Destroy session key. 
	if(hKey)
	{
		CryptDestroyKey(hKey);
	} 

	return TRUE;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -