Я новичок в AES, но из того, что я обнаружил, существует несколько режимов (ECB, CBC и т. д.), и для разных режимов требуются разные требования к вектору инициализации, блоки и кодировки. Я пытаюсь расшифровать следующее
Xrb9YtT7cHUdpHYIvEWeJIAbkxWUtCNcjdzOMgyxJzU/vW9xHivdEDFKeszC93B6MMkhctR35e+YkmYI5ejMf5ofNxaiQcZbf3OBBsngfWUZxfvnrE2u1lD5+R6cn88vk4+mwEs3WoAht1CAkjr7P+fRIaCTckWLaF9ZAgo1/rvYA8EGDc+uXgWv9KvYpDDsCd1JStrD96IACN3DNuO28lVOsKrhcEWhDjAx+yh72wM=
используя php и (текстовый) ключ «043j9fmd38jrr4dnej3FD11111111111» с режимом CBC и IV всех нулей. Я могу заставить его работать с этим инструментом, но не могу получить его в 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 или сначала превратить ключ в двоичный код. Я пытался расшифровать многие вещи, и все, что я могу сделать, это тарабарщина. Любая помощь будет очень признательна.