我正在使用 mcrypt_encrypt 和 base64_encode 来加密 php 中的数据。我试过用 C++ 解密数据,但无济于事。我有多年来使用的 C++ Rijndael 逻辑,以及 base64_decode 逻辑。后者完美解码由 php 的 base64_encode 编码的字符串。我将 CBC 与 php 和 C++ 一起使用。我已经尝试过不同的块大小等等,但无济于事。非常感谢任何建议。
这是我的测试逻辑:
PHP
$key = "qwertyuiopasdfghjklzxcvbnmqwerty";
$iv = "12345678901234561234567890123456";
$text = "this is the text to encrypt";
$crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $text, MCRYPT_MODE_CBC, $iv);
echo base64_encode($crypttext)."<br/>";
C++
char* base64encode = ".. output from php...";
unsigned char binaryData[256];
int binaryNumBytes;
char result[256];
base64_decode(reinterpret_cast<unsigned char*>(base64encode), strlen(base64encode), binaryData, &binaryNumBytes, false);
Encryption::Rijndael rijndael;
char* key = "qwertyuiopasdfghjklzxcvbnmqwerty";
char* iv = "12345678901234561234567890123456";
rijndael.Init(Encryption::Rijndael::CBC, reinterpret_cast<const char*>(key), 32, 32, reinterpret_cast<const char*>(iv));
rijndael.Decrypt(reinterpret_cast<const char*>(binaryData), reinterpret_cast<char*>(result), 32);
cout << result << endl;
编辑:如果我使用 ECB 模式,我可以让它工作。2之间的CBC存在一些问题。