0

必须使用 4 字节 IV 加密一些数据。但是,我使用的加密算法(AES128)需要一个 16 字节(128 位)的密钥。说,我的代码如下:

#include<gcrypt.h>
void encrypt(){
    int IV = 6174;
    gcry_cipher_hd_t hd;        
    errStatus = gcry_cipher_open(&hd, GCRY_CIPHER_AES128, GCRY_CIPHER_MODE_CBC, 0);
    errStatus = gcry_cipher_setkey(hd, keyBuffer, 16);
    gcry_cipher_setiv(hd, &IV, 16);
    gcry_cipher_encrypt(hd, output, 16, bytesToEncrypt, 16);
}

keyBuffer包含一个 16 字节的密钥bytes,和输出分别是我的输入和输出。我该如何正确地进行静脉注射?

4

1 回答 1

0

您可以尝试使用此代码来避免缓冲区溢出吗?不过,我自己还没有测试过

int IV[4] = { 6174 }; // { 6174, 0, 0, 0 }
于 2014-01-24T01:28:33.750 回答