C++Builder 6(BCB 6)RSA暗号化

3072 ワード

前言:プロジェクトは鍵に基づいて暗号化する必要があり、クライアントは公開鍵に基づいて復号し、ここではRSAを使用して復号する.
プロジェクトにopensslのダイナミックリンクライブラリをインポートするlibeay 32.dll, libeay32.lib、工事環境を配置し、コード:
/**
* @author:  HanshuaiWu
* @methodsName: encrypt
* @description:   
* @param1:  orgData:   
* @param2:  publicKey:  
* @return: AnsiString
* @createTime: 2018/11/9
*/
extern "C" {
AnsiString TIDCard::encrypt(AnsiString orgData)
{      //C:\Users\Administrator\Desktop\     v1.0    \CardServerV2\Output\key.pem


     char *p_en = NULL;
     RSA *p_rsa = NULL;
     FILE *file = NULL;
     AnsiString pathStr = "key.pem";
     char *path_key = (char *)pathStr.c_str();
     int  rsa_len = 0;    //flen      , rsa_len     


     //1.      
     if((file = fopen(path_key, "r")) == NULL)
     {
         return-1;
     }

     BIO *in = NULL;
     in = BIO_new(BIO_s_file());
     if( BIO_read_filename(in, path_key) != 1)
     {
        return -1;
     }

     if(in == NULL){
       return -1;
     }

     p_rsa = PEM_read_bio_RSAPrivateKey(in , NULL, NULL, NULL);

     //3.       
     rsa_len = RSA_size(p_rsa);

     //4.            (       )
     p_en = (char *)malloc(rsa_len);
     if(!p_en)
     {
          return -1;
     }
     memset(p_en, 0, rsa_len);
       int length =  orgData.Length();
       char *orgBuffer = (char *) malloc(length);;
       orgBuffer = (char *)AnsiToUtf8(orgData).c_str();

       int len = RSA_private_encrypt(strlen(orgBuffer), orgBuffer, p_en, p_rsa, RSA_PKCS1_PADDING);
       AnsiString result = Encode(p_en, len);
        //  free
    free_all:
    fclose(file);
    BIO_free_all(in);
    RSA_free(p_rsa);
    free(p_en);
    free(orgBuffer);
       return result;
}
}
// base64  
AnsiString TIDCard::Encode(const unsigned char* Data,int DataByte)
{
    //   
    const char EncodeTable[]="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
    //   
    AnsiString strEncode;
    unsigned char Tmp[4]={0};
    int LineLength=0;
    for(int i=0;i> 2];
        strEncode+= EncodeTable[((Tmp[1] << 4) | (Tmp[2] >> 4)) & 0x3F];
        strEncode+= EncodeTable[((Tmp[2] << 2) | (Tmp[3] >> 6)) & 0x3F];
        strEncode+= EncodeTable[Tmp[3] & 0x3F];
        if(LineLength+=4,LineLength==76) {
                //strEncode+="\r
"; LineLength=0; } } // int Mod=DataByte % 3; if(Mod==1) { Tmp[1] = *Data++; strEncode+= EncodeTable[(Tmp[1] & 0xFC) >> 2]; strEncode+= EncodeTable[((Tmp[1] & 0x03) << 4)]; strEncode+= "=="; } else if(Mod==2) { Tmp[1] = *Data++; Tmp[2] = *Data++; strEncode+= EncodeTable[(Tmp[1] & 0xFC) >> 2]; strEncode+= EncodeTable[((Tmp[1] & 0x03) << 4) | ((Tmp[2] & 0xF0) >> 4)]; strEncode+= EncodeTable[((Tmp[2] & 0x0F) << 2)]; strEncode+= "="; } return strEncode; }

好きな仲間は好きな人や注目してください.あなたたちの励ましは私の前進の原動力です.