RSA加密解密代码

RSA加密解密代码(Ubuntu下)

下面是一个用C++和OpenSSL库在Ubuntu下进行RSA加密和解密的验证代码示例。你可以用它来测试RSA加密和解密的过程。

安装OpenSSL库(如果尚未安装):

sudo apt-get install libssl-dev

RSA加密和解密代码(rsa_example.cpp):

#include

#include <openssl/rsa.h>

#include <openssl/pem.h>

#include <openssl/err.h>

#include

using namespace std;

// 打印错误信息

void print_errors() {

char buffer120;

while (ERR_get_error()) {

ERR_error_string_n(ERR_get_error(), buffer, sizeof(buffer));

cout << buffer << endl;

}

}

// 生成RSA密钥对并保存

void generate_rsa_keys() {

RSA* rsa = RSA_new();

BIGNUM* bn = BN_new();

if (!BN_set_word(bn, RSA_F4)) {

print_errors();

return;

}

复制代码
if (!RSA_generate_key_ex(rsa, 2048, bn, NULL)) {
    print_errors();
    return;
}

// 保存私钥
FILE* privateKeyFile = fopen("private.pem", "wb");
PEM_write_RSAPrivateKey(privateKeyFile, rsa, NULL, NULL, 0, NULL, NULL);
fclose(privateKeyFile);

// 保存公钥
FILE* publicKeyFile = fopen("public.pem", "wb");
PEM_write_RSAPublicKey(publicKeyFile, rsa);
fclose(publicKeyFile);

RSA_free(rsa);
BN_free(bn);

}

// 使用RSA公钥加密

int encrypt_with_rsa_public_key(const string& message, unsigned char** encryptedMessage) {

FILE* publicKeyFile = fopen("public.pem", "rb");

RSA* rsa = PEM_read_RSAPublicKey(publicKeyFile, NULL, NULL, NULL);

fclose(publicKeyFile);

复制代码
int rsaSize = RSA_size(rsa);
*encryptedMessage = (unsigned char*)malloc(rsaSize);

int result = RSA_public_encrypt(message.length(), (unsigned char*)message.c_str(), *encryptedMessage, rsa, RSA_PKCS1_OAEP_PADDING);
if (result == -1) {
    print_errors();
    RSA_free(rsa);
    return -1;
}

RSA_free(rsa);
return result;

}

// 使用RSA私钥解密

string decrypt_with_rsa_private_key(unsigned char* encryptedMessage, int encryptedMessageLen) {

FILE* privateKeyFile = fopen("private.pem", "rb");

RSA* rsa = PEM_read_RSAPrivateKey(privateKeyFile, NULL, NULL, NULL);

fclose(privateKeyFile);

复制代码
unsigned char* decryptedMessage = (unsigned char*)malloc(RSA_size(rsa));
int result = RSA_private_decrypt(encryptedMessageLen, encryptedMessage, decryptedMessage, rsa, RSA_PKCS1_OAEP_PADDING);
if (result == -1) {
    print_errors();
    RSA_free(rsa);
    return "";
}

string decryptedText((char*)decryptedMessage, result);
RSA_free(rsa);
free(decryptedMessage);

return decryptedText;

}

int main() {

// 生成密钥对

generate_rsa_keys();

复制代码
string message = "Hello, RSA Encryption!";
cout << "Original Message: " << message << endl;

// 使用RSA公钥加密
unsigned char* encryptedMessage = NULL;
int encryptedMessageLen = encrypt_with_rsa_public_key(message, &encryptedMessage);
if (encryptedMessageLen == -1) {
    return 1;
}

// 打印加密后的数据
cout << "Encrypted Message: ";
for (int i = 0; i < encryptedMessageLen; i++) {
    printf("%02x ", encryptedMessage[i]);
}
cout << endl;

// 使用RSA私钥解密
string decryptedMessage = decrypt_with_rsa_private_key(encryptedMessage, encryptedMessageLen);
cout << "Decrypted Message: " << decryptedMessage << endl;

free(encryptedMessage);
return 0;

}

代码解释:

生成RSA密钥对:generate_rsa_keys函数会生成2048位的RSA密钥对,并将它们分别保存为private.pem和public.pem。

RSA公钥加密:encrypt_with_rsa_public_key函数使用公钥对消息进行加密。

RSA私钥解密:decrypt_with_rsa_private_key函数使用私钥解密加密后的消息。

加密后输出:加密后的数据以十六进制格式输出,便于查看。

编译与运行:

编译代码:

g++ -o rsa_example rsa_example.cpp -lssl -lcrypto

运行:

./rsa_example

输出示例:

相关推荐
云泽80810 小时前
C++ 可调用对象通关指南:深度解析 Lambda 表达式、function 包装器与 bind 绑定器
开发语言·c++·算法
Tri_Function10 小时前
简单图论大学习
c++
lqqjuly11 小时前
C++ 完整知识体系—从基础语法到现代 C++23 的系统性总结
c++·c++23
王老师青少年编程11 小时前
信奥赛C++提高组csp-s之FHQ Treap
c++·csp·平衡树·信奥赛·csp-s·提高组·fhq treap
星恒随风11 小时前
Python 基础语法详解(一):从表达式、变量到数据类型
开发语言·笔记·python·学习
888CC++11 小时前
java 并发编程
java·开发语言·python
罗超驿12 小时前
18.Web API 实战:元素与表单属性的获取和修改
开发语言·前端·javascript
被子你放开我12 小时前
CRMEB PHP多商户升级4.0太麻烦了
开发语言·php
阿里嘎多学长12 小时前
2026-06-01 GitHub 热点项目精选
开发语言·程序员·github·代码托管