使用windows crypto API加密解密
时间: 2023-09-04 08:06:33 浏览: 167
Windows Crypto API 是一组用于数据加密和解密的功能和接口,它被广泛应用于 Windows 操作系统中的安全相关应用程序中。下面是一个简单的示例代码,演示如何使用 Windows Crypto API 进行数据加密和解密:
```c++
#include <iostream>
#include <Windows.h>
#include <Wincrypt.h>
#pragma comment (lib, "Crypt32.lib")
int main() {
// 初始化 crypto API
HCRYPTPROV hCryptProv;
if (!CryptAcquireContext(&hCryptProv, NULL, NULL, PROV_RSA_AES, 0)) {
std::cerr << "CryptAcquireContext failed: " << GetLastError() << std::endl;
return 1;
}
// 生成随机密钥
HCRYPTKEY hKey;
if (!CryptGenKey(hCryptProv, CALG_AES_256, CRYPT_EXPORTABLE, &hKey)) {
std::cerr << "CryptGenKey failed: " << GetLastError() << std::endl;
CryptReleaseContext(hCryptProv, 0);
return 1;
}
// 加密数据
const char* plainText = "Hello, world!";
DWORD plainTextLength = strlen(plainText) + 1;
DWORD cipherTextLength = 0;
if (!CryptEncrypt(hKey, NULL, TRUE, 0, NULL, &cipherTextLength, plainTextLength)) {
std::cerr << "CryptEncrypt failed: " << GetLastError() << std::endl;
CryptDestroyKey(hKey);
CryptReleaseContext(hCryptProv, 0);
return 1;
}
char* cipherText = new char[cipherTextLength];
memcpy(cipherText, plainText, plainTextLength);
if (!CryptEncrypt(hKey, NULL, TRUE, 0, reinterpret_cast<BYTE*>(cipherText), &plainTextLength, cipherTextLength)) {
std::cerr << "CryptEncrypt failed: " << GetLastError() << std::endl;
CryptDestroyKey(hKey);
CryptReleaseContext(hCryptProv, 0);
delete[] cipherText;
return 1;
}
// 解密数据
DWORD decryptedTextLength = 0;
if (!CryptDecrypt(hKey, NULL, TRUE, 0, NULL, &decryptedTextLength)) {
std::cerr << "CryptDecrypt failed: " << GetLastError() << std::endl;
CryptDestroyKey(hKey);
CryptReleaseContext(hCryptProv, 0);
delete[] cipherText;
return 1;
}
char* decryptedText = new char[decryptedTextLength];
memcpy(decryptedText, cipherText, cipherTextLength);
if (!CryptDecrypt(hKey, NULL, TRUE, 0, reinterpret_cast<BYTE*>(decryptedText), &decryptedTextLength)) {
std::cerr << "CryptDecrypt failed: " << GetLastError() << std::endl;
CryptDestroyKey(hKey);
CryptReleaseContext(hCryptProv, 0);
delete[] cipherText;
delete[] decryptedText;
return 1;
}
std::cout << "Original text: " << plainText << std::endl;
std::cout << "Encrypted text: " << cipherText << std::endl;
std::cout << "Decrypted text: " << decryptedText << std::endl;
// 清理
delete[] cipherText;
delete[] decryptedText;
CryptDestroyKey(hKey);
CryptReleaseContext(hCryptProv, 0);
return 0;
}
```
在上面的示例代码中,我们首先使用 `CryptAcquireContext` 函数初始化 crypto API,然后使用 `CryptGenKey` 函数生成一个随机密钥,接着使用 `CryptEncrypt` 函数对数据进行加密,最后使用 `CryptDecrypt` 函数对数据进行解密。请注意,这里使用的是 AES-256 对称加密算法,你可以根据需要选择其他加密算法。
阅读全文