c 语言常用的加密算法——RSA加密算法
2023-12-14 06:52:58
在C语言中,常用的加密算法包括以下几种:
- AES加密算法:这是一种对称加密算法,广泛用于数据加密。在C语言中,可以使用openssl库来实现AES加密。
- RSA加密算法:这是一种非对称加密算法,即加密和解密使用两把不同的密钥。RSA是最为常见的非对称加密算法,也是目前最为成熟的一种。在C语言中,可以使用openssl库来实现RSA加密。
- MD5算法:这是一种广泛使用的加密散列函数,可以产生一个128位的散列值。在C语言中,可以使用openssl库来实现MD5加密。
- SHA-1算法:全称是Secure Hash Algorithm 1,这是一种密码哈希函数,可用于数字签名和验证、消息摘要等。在C语言中,同样可以使用openssl库来实现SHA-1加密。
- Base64编码:严格来说这不是一种加密算法,而是一种编码方式。但是,由于其可以一定程度上隐藏信息,因此也常被用于简单的“加密”。在C语言中,可以使用openssl库来进行Base64编码和解码。
以上这些算法在C语言中实现时,通常会使用到openssl这样的第三方库,因为这些库已经实现了这些算法的高效实现,直接使用。
RSA是一种非对称加密算法,使用一对密钥:一个公钥用于加密数据,一个私钥用于解密数据。在C语言中,可以使用openssl库来实现RSA加密。
以下是一个简单的示例,说明如何使用RSA公钥加密数据:
#include <stdio.h>
#include <openssl/rsa.h>
#include <openssl/pem.h>
#include <openssl/err.h>
int main() {
// 读取公钥文件
FILE *fp = fopen("public.pem", "r");
if (fp == NULL) {
printf("Failed to open public key file\n");
return -1;
}
RSA *rsa = PEM_read_RSA_PUBKEY(fp, NULL, NULL, NULL);
fclose(fp);
if (rsa == NULL) {
printf("Failed to read public key\n");
return -1;
}
// 要加密的数据
char message[] = "Hello, world!";
int message_len = strlen(message);
// 加密数据
unsigned char encrypted_message[RSA_size(rsa)];
int encrypted_message_len = RSA_public_encrypt(message_len, (const unsigned char*)message, encrypted_message, rsa, RSA_PKCS1_PADDING);
if (encrypted_message_len == -1) {
printf("Encryption failed\n");
return -1;
}
// 输出加密后的数据(16进制格式)
for (int i = 0; i < encrypted_message_len; i++) {
printf("%02x", encrypted_message[i]);
}
printf("\n");
// 释放资源
RSA_free(rsa);
return 0;
}
????????在这个示例中,我们首先读取了公钥文件,然后使用PEM_read_RSA_PUBKEY
函数将其解析为一个RSA
结构体。然后,我们定义了要加密的数据,并使用RSA_public_encrypt
函数对其进行加密。最后,我们输出加密后的数据(以16进制格式)。请注意,这只是一个简单的示例,实际应用中可能需要更复杂的错误处理和资源管理。
欢迎大家关注我的今日头条博客:https://www.toutiao.com/c/user/token/MS4wLjABAAAASxqllWGhgHVw37LkDg7jmwBC5JPgurGsvTSIVv-1kbvKBEnn0Ps70sBEw8MdDpMO/?source=mp_msg
文章来源:https://blog.csdn.net/A185822153/article/details/134813536
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!