我正在尝试用 C++ 解密文件。该文件使用以下命令加密:
openssl enc -nosalt -aes-128-cbc -pass pass:test -in "test.txt" -out "test_enc.txt" -p
控制台显示key=098F6BCD4621D373CADE4E832627B4F6
and iv=0A9172716AE6428409885B8B829CCB05
.
在 C++ 中我已经包含了#include openssl/aes.h
行并尝试使用以下代码解密:
const char *indata = string.toAscii().constData();
unsigned char outdata[strlen(indata)];
unsigned char ckey[] = "098F6BCD4621D373CADE4E832627B4F6";
unsigned char ivec[] = "0A9172716AE6428409885B8B829CCB05";
/* data structure that contains the key itself */
AES_KEY key;
/* set the encryption key */
AES_set_decrypt_key(ckey, 256, &key);
AES_cbc_encrypt((unsigned char*) indata, outdata, strlen(indata), &key, ivec, AES_DECRYPT);
QString result = QString((const char*) outdata);
return result;
变量 outdata 包含与使用 OpenSSL 加密之前不同的值。
您指定-aes-128-cbc
作为 OpenSSL 上的一个选项,因此密钥和初始化向量将是128 bits long. openssl
将这些打印出来为十六进制字符串,因为如果打印二进制文件,它们会在控制台上被混淆。
因此你应该初始化你的ckey[]
and ivec[]
作为十六进制字符串的二进制值,如下所示:
unsigned char ckey[] = "\x09\x8F\x6B\xCD\x46\x21\xD3\x73\xCA\xDE\x4E\x83\x26\x27\xB4\xF6";
unsigned char ivec[] = "\x0A\x91\x72\x71\x6A\xE6\x42\x84\x09\x88\x5B\x8B\x82\x9C\xCB\x05";
并且还使用密钥长度128代替256 in:
AES_set_decrypt_key(ckey, 128, &key);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)