我的目标是解密base64编码的字符串。
完全运行命令:
openssl enc -base64 -d -aes-128-cbc -iv '{iv}' -K {hex_key} <<< {hex_enc_password}
我想通过C api做同样的事情。我知道stackoverflow上有很多类似的问题,但似乎没有什么对我有用,所以我恳请你
将此标记为重复。
信息:
十六进制密码
是base64编码的
六角键
我的当前代码:
char* key = "lbzA54tAAg3E/jPxiJc34e==";
unsigned char *hex_key = hexlify(key);
char encrypted[] = {0x3d,0xd2,0x02,0xc3,0xae,0x1e,0xf5,0x7e,0x33,0xc3,0x1d,0x7b,0x1e,0x48,0x73,0x84};
size_t output_length;
unsigned char *hex_enc_password = base64_encode(encrypted, sizeof(encrypted), &output_length);
decrypt(hex_enc_password, strlen(hex_enc_password),hex_key, iv);
char* decrypt(unsigned char *ciphertext, int ciphertext_len, unsigned char *key, unsigned char *iv ) {
int outLen1 = 0; int outLen2 = 0;
unsigned char *outdata = malloc(ciphertext_len+1);
bzero(outdata, ciphertext_len+1);
//setup decryption
EVP_CIPHER_CTX *ctx = EVP_CIPHER_CTX_new();
EVP_DecryptInit(ctx,EVP_aes_128_cbc(),key,iv); //returns 1
EVP_DecryptUpdate(ctx,outdata,&outLen1,ciphertext,ciphertext_len); //returns 1
EVP_DecryptFinal(ctx,outdata + outLen1,&outLen2); //returns 0
return outdata;
}
有什么问题吗?