【发布时间】:2017-08-06 15:22:34
【问题描述】:
我正在尝试使用 AES 加密字节数组。我已经能够加密字符串和文件没问题,但是字节数组似乎对我不起作用。我传入一个要加密的字节数组,为了便于测试,我只传入由 crypto++ (bArrayToEncrypt) 生成的 AES 密钥。加密似乎有效,但解密确实有效。我还发现加密有大量重复字符很奇怪。我在这里做错了什么??
我看到了一个类似的问题Here,但它与 RSA 有关 以及提供的示例加密我已经运行的字符串。
如何调用函数:
size_t ksize = CryptoPP::AES::MAX_KEYLENGTH;
size_t vsize = CryptoPP::AES::BLOCKSIZE;
byte key[ksize];
byte testArray[ksize];
byte encryptedksize];
byte decrypted[ksize];
byte iv[vsize];
//generate key & iv, then generate a random byte array to encrypt/decrypt
CryptoPP::AutoSeededRandomPool prng;
prng.GenerateBlock(key, ksize);
prng.GenerateBlock(iv, vsize);
prng.GenerateBlock(testArray, ksize);
encrypt_barray(key, ksize, iv, vsize, testArray, ksize, encrypted);
//printed results here
decrypt_barray(key, ksize, iv, vsize, encrypted, ksize, decrypted);
//printed results here
加密数组
void encrypt_barray(byte* key,
size_t kSize,
byte* iv,
size_t ivSize,
byte* bArrayToEncrypt,
size_t bArraySize,
byte* encrypted) {
CryptoPP::CBC_Mode<CryptoPP::AES>::Encryption e;
e.SetKeyWithIV(key, kSize, iv, ivSize);
CryptoPP::ArraySource(key, true,
new CryptoPP::StreamTransformationFilter(e, new CryptoPP::ArraySink(encrypted, bArraySize)));
}
解密数组
void decrypt_barray(byte* key,
size_t kSize,
byte* iv,
size_t ivSize,
byte* bArrayToDecrypt,
size_t bArraySize,
byte* decrypted) {
CryptoPP::CBC_Mode<CryptoPP::AES>::Decryption d;
d.SetKeyWithIV(keyFromHash, kfhSize, iv1, iv1Size);
CryptoPP::ArraySource(keyToDecrypt, true,
new CryptoPP::StreamTransformationFilter(d, new CryptoPP::ArraySink(decrypted, bArraySize)));
}
输出:
Encrypted: ╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠
╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠E1A2AFC5D820ADF7
7DB656DEF3245570╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠
╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠
╨Ñ♫
Decrypted: ╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠E
1A2AFC5D820ADF77DB656DEF3245570╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠
╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠
╠╠╠╠╠╠╠╠╠╠╠╠╠╠╠╨Ñ♫
Press any key to continue . . .
【问题讨论】:
-
ArraySink是适合这项工作的错误工具。您无法从加密操作中获取密文的实际大小。然后,在解密过程中,您会失明,因为您不知道ArraySource使用什么大小。考虑切换到std::string或ByteQueue。另请参阅 Crypto++ wiki 上的 SecByteBlockSink。 -
另外,
E1A2AFC5D820ADF77DB656DEF3245570和E1A2AFC5D820ADF77DB656DEF3245570在我看来几乎就像一个串联的内存位置(即指针)。您可能应该展示您调用encrypt_barray和decrypt_barray的方式。 -
@jww 我继续并添加了我如何调用这两个函数。谢谢!
-
如何将 ByteQueue 合并到这些函数中?
-
由于操作模式和 PKCS 填充,密文将大于
testArray[ksize]。ArraySink将最多存储ksize字节,然后停止写入数组。
标签: c++ encryption crypto++