OpenSSL RSA算法 非对称加密

本文介绍了一个使用OpenSSL库实现RSA非对称加密的简单程序。通过生成公钥和私钥,利用公钥加密,私钥解密进行数据保护。详细步骤包括密钥生成、公钥和私钥的加载以及加密和解密操作,特别指出加密和解密时需要注意的最大字节长度限制。提供了一个完整示例的下载链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


    最近用OpenSSL 的RSA加解密算法,做了个非对称加密的小程序,写上来给大伙儿瞅瞅。

    OpenSSL的下载,编译,配置,略过。

    大概分以下几步:

首先,生成秘钥:

     注意,非对称加密生成一对秘钥,公钥,私钥。公钥加密,私钥解密。私钥解密得有密码,而且我只研究了公钥加密,私钥解密这一种方法。

     公钥生成:

     RSA* rsa = RSA_generate_key(KeyLength, RSA_F4, NULL, NULL);

     KeyLength在这里是密钥长度,256,512,1024,2048等等。

     长度越长,加密后的文件越大,针对同一段文字生成的密文也越长。另外,记下这个长度,后面解密时会用到。RSA_F4是对应的算法。后面两个参数不用,略过。
     BIO *bp = BIO_new(BIO_s_file());

     新搞一个文件指针
     BIO_write_filename(bp, cTemp);

     真正的创建这个文件,调试时发现好象不支持中文路径,不知道是我的问题还是OPENSSL的问题,没有关注。
     PEM_write_bio_RSAPublicKey(bp, rsa);

     rsa 和 bp相关联。
     BIO_free_all(bp);

     释放资源。

     

     私钥生成:

      大致和公钥生成差不多,只是私钥必需要创建密码,否则生成失败。cPassTemp是私钥密码,

bp = BIO_new_file(cTemp, "wb+");

cTemp是密钥路径。
        PEM_write_bio_RSAPrivateKey(bp, rsa, EVP_des_ede3(), (unsigned                                     char*)cPassTemp, strPrivatePassword.GetLength(), NULL, NULL);
  cPassTemp是密码,后面跟着密码长度。
BIO_free_all(bp);
RSA_free(rsa);

释放资源。


第二步,打开公钥(私钥):

        公钥:

        EVP_PKEY* key = NULL;
RSA * m_pRsaPublic = NULL;

BIO *bp = BIO_new(BIO_s_file());;
BIO_read_filename(bp, strKeyFile);

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值