我是AES新手,但从我发现的有几种模式(ECB,CBC等),不同的模式需要不同的初始化矢量要求,块和编码。我想下面的AES解密在PHP
Xrb9YtT7cHUdpHYIvEWeJIAbkxWUtCNcjdzOMgyxJzU/vW9xHivdEDFKeszC93B6MMkhctR35e+YkmYI5ejMf5ofNxaiQcZbf3OBBsngfWUZxfvnrE2u1lD5+R6cn88vk4+mwEs3WoAht1CAkjr7P+fRIaCTckWLaF9ZAgo1/rvYA8EGDc+uXgWv9KvYpDDsCd1JStrD96IACN3DNuO28lVOsKrhcEWhDjAx+yh72wM=
使用PHP和(文本)键“043j9fmd38jrr4dnej3FD11111111111”与模式CBC和全零的IV解码。我能够得到它与this tool,但无法在PHP中获得它。这里是我使用的代码:
function decrypt_data($data, $iv, $key) {
$data = base64_decode($data);
$cypher = mcrypt_module_open(MCRYPT_RIJNDAEL_256, '', MCRYPT_MODE_CBC, '');
// initialize encryption handle
if (mcrypt_generic_init($cypher, $key, $iv) != -1) {
// decrypt
$decrypted = mdecrypt_generic($cypher, $data);
// clean up
mcrypt_generic_deinit($cypher);
mcrypt_module_close($cypher);
return $decrypted;
}
return false;
}
我想我可能失去了一些东西与base 64编码或转动钥匙到进位争先。我试着解码很多东西,我所能产生的只是乱码。任何帮助将非常感激。
你有一个base64编码的字符串。在将它提供给mcrypt之前,它必须解码回二进制垃圾。 – 2012-04-05 04:23:45
我曾试过......它可能是它的一部分,但我仍然得到了胡言乱语,即使这样做......我会更新我的问题,以显示它虽然 – hackartist 2012-04-05 04:28:23