7
例如,在:OpenSSL:對於加密/解密例程,可以輸入和輸出緩衝區是否相同?
int EVP_EncryptUpdate(EVP_CIPHER_CTX *ctx, unsigned char *out,
int *outl, unsigned char *in, int inl);
...可以out
== in
?
例如,在:OpenSSL:對於加密/解密例程,可以輸入和輸出緩衝區是否相同?
int EVP_EncryptUpdate(EVP_CIPHER_CTX *ctx, unsigned char *out,
int *outl, unsigned char *in, int inl);
...可以out
== in
?
我只是偶然發現了這個問題,因爲我很好奇自己。由於沒有人回答,我嘗試了它,它確實工作(至少與AES CTR 128解密),所以我敢冒險猜測它也適用於其他類型。如果你有興趣,這是我的代碼示例。
/* Test Vector from http://www.inconteam.com/software-development/41-encryption/55-aes-test-vectors */
const unsigned char key[16] = { 0x2b, 0x7e, 0x15, 0x16,
0x28, 0xae, 0xd2, 0xa6,
0xab, 0xf7, 0x15, 0x88,
0x09, 0xcf, 0x4f, 0x3c };
const unsigned char IV[16] = { 0xf0, 0xf1, 0xf2, 0xf3,
0xf4, 0xf5, 0xf6, 0xf7,
0xf8, 0xf9, 0xfa, 0xfb,
0xfc, 0xfd, 0xfe, 0xff };
unsigned char test[16] = { 0x6b, 0xc1, 0xbe, 0xe2,
0x2e, 0x40, 0x9f, 0x96,
0xe9, 0x3d, 0x7e, 0x11,
0x73, 0x93, 0x17, 0x2a };
EVP_CIPHER_CTX mCtx;
EVP_DecryptInit(&mCtx, EVP_aes_128_ctr(), key, IV);
int out_size;
EVP_DecryptUpdate(&mCtx, test, &out_size, test, 16);
我也試過用加密技術(AES 128 CBC),它可以工作。 – apanloco 2017-12-06 09:13:06
我猜不行,但你有沒有試過?我很高興知道。 – Francois 2011-09-22 08:49:06