RSA加解密 公鑰加密私鑰解密 公加私解 && C++ 調用openssl庫 的代碼實例

前提:祕鑰長度=1024html

==============================================函數

    對一片(117字節)明文加密加密

==============================================spa

// 公鑰加密    
std::string rsa_pub_encrypt(const std::string &clearText,  std::string &pubKey)  
{  
    std::string strRet;  
    BIO *keybio = BIO_new_mem_buf((unsigned char *)pubKey.c_str(), -1);  
    //keybio = BIO_new_mem_buf((unsigned char *)strPublicKey.c_str(), -1);  
    // 此處有三種方法  
    // 1, 讀取內存裏生成的密鑰對,再從內存生成rsa  
    // 2, 讀取磁盤裏生成的密鑰對文本文件,在從內存生成rsa  
    // 3,直接從讀取文件指針生成rsa  
    //RSA* pRSAPublicKey = RSA_new();  
    RSA* rsa = RSA_new();
    rsa = PEM_read_bio_RSAPublicKey(keybio, &rsa, NULL, NULL);
    if (!rsa)
    {
            BIO_free_all(keybio);
            return std::string("");
    }

    int len = RSA_size(rsa);  
    //int len = 1028;
    char *encryptedText = (char *)malloc(len + 1);  
    memset(encryptedText, 0, len + 1);  
  
    // 加密函數  
    int ret = RSA_public_encrypt(clearText.length(), (const unsigned char*)clearText.c_str(), (unsigned char*)encryptedText, rsa, RSA_PKCS1_PADDING);  
    if (ret >= 0)  
        strRet = std::string(encryptedText, ret);  
  
    // 釋放內存  
    free(encryptedText);  
    BIO_free_all(keybio);  
    RSA_free(rsa);
  
    return strRet;  
}  

==============================================指針

    對一片(128字節)密文解密code

==============================================htm

// 私鑰解密    
std::string rsa_pri_decrypt(const std::string &cipherText, const std::string &priKey)  
{  
    std::string strRet;  
    RSA *rsa = RSA_new();  
    BIO *keybio;  
    keybio = BIO_new_mem_buf((unsigned char *)priKey.c_str(), -1);  
  
    // 此處有三種方法  
    // 1, 讀取內存裏生成的密鑰對,再從內存生成rsa  
    // 2, 讀取磁盤裏生成的密鑰對文本文件,在從內存生成rsa  
    // 3,直接從讀取文件指針生成rsa  
    rsa = PEM_read_bio_RSAPrivateKey(keybio, &rsa, NULL, NULL);  
  
    int len = RSA_size(rsa);  
    char *decryptedText = (char *)malloc(len + 1);  
    memset(decryptedText, 0, len + 1);  
  
    // 解密函數  
    int ret = RSA_private_decrypt(cipherText.length(), (const unsigned char*)cipherText.c_str(), (unsigned char*)decryptedText, rsa, RSA_PKCS1_PADDING);  
    if (ret >= 0)  
        strRet = std::string(decryptedText, ret);  
  
    // 釋放內存  
    free(decryptedText);  
    BIO_free_all(keybio);  
    RSA_free(rsa);  
  
    return strRet;  
}  

 

 

注:工做中只用到了 rsa私加公解,所以沒有 針對所有明文的公加私解的代碼實現,請參考附錄。blog

附:rsa 私加公解ip

相關文章
相關標籤/搜索