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 buffer[120];

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

输出示例:

相关推荐
梓䈑9 小时前
【CMake】动静态库的安装 和 使用
c++·cmake
weixin_449290019 小时前
uv打包Python为exe步骤
开发语言·python·uv
Yupureki9 小时前
《Linux网络编程》1.网络基础
linux·运维·服务器·c语言·网络·c++
csdn2015_9 小时前
Set<String> 类型取第一条记录
开发语言·windows·python
十五年专注C++开发9 小时前
银河麒麟V10系统安装vcpkg的方法
c++·cmake·vcpkg
未来之窗软件服务9 小时前
SenseVoicecpp ggml-webgpu大模型[AI人工智能(七十五)]—东方仙盟
c++·人工智能·算法·仙盟创梦ide·东方仙盟
寂柒9 小时前
C++——堆
开发语言·c++
邂逅星河浪漫9 小时前
【Java】@EqualsAndHashCode 注解解析
java·开发语言
卖芒果的潇洒农民9 小时前
C语言面试
c语言·开发语言·面试
郝学胜-神的一滴9 小时前
解锁CS数据存储的核心逻辑:从结构选择到表单设计的全解析
linux·服务器·数据库·c++·后端·oracle