Идея состоит в том, чтобы AES зашифровать строку и отправить ее на мой сервер, а затем расшифровать ее там, чтобы получить настоящую строку. Но это не сработало, и, как ни странно, я обнаружил, что результат отличается, даже когда вы шифруете строку AES-256 на python и php соответственно.
Пример Python:
from Crypto.Cipher import AES
import base64
original = "originalstring"
key = "12345678123456781234567812345678"
IV = "1234567812345678"
b64encodedOnly = base64.b64encode(original)
encryptCipher = AES.new(key, AES.MODE_CFB, IV)
encrypted = base64.b64encode(encryptCipher.encrypt(original))
decryptCipher = AES.new(key, AES.MODE_CFB, IV)
decrypted = decryptCipher.decrypt(base64.b64decode(encrypted))
print "original:", original
print "b64encoded only:", b64encodedOnly
print "AES-256 encrypted:", encrypted
print "AES-256 decrypted:", decrypted
Вывод Python:
original: originalstring
b64encoded only: b3JpZ2luYWxzdHJpbmc=
AES-256 encrypted: Rl4MMQojmBm0e6iuCl8=
AES-256 decrypted: originalstring
Пример PHP:
<?php
$original = "originalstring";
$key = "12345678123456781234567812345678";
$IV = "1234567812345678";
$b64encodedOnly = base64_encode($original);
$encrypted = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $original, MCRYPT_MODE_CFB, $IV));
$decrypted = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, base64_decode($encrypted), MCRYPT_MODE_CFB, $IV);
echo "original: " . $original . "<br />";
echo "b64encoded only: " . $b64encodedOnly . "<br />";
echo "AES-256 encrypted: " . $encrypted . "<br />";
echo "AES-256 decrypted: " . $decrypted . "<br />";
?>
Вывод PHP:
original: originalstring
b64encoded only: b3JpZ2luYWxzdHJpbmc=
AES-256 encrypted: +w9F6zLD2avTt9fj8aM=
AES-256 decrypted: originalstring
Как вы можете видеть, после шифрования AES-256 (режим CFB), а затем кодировки base64, "originalstring"
превращается в "Rl4MMQojmBm0e6iuCl8="
на python, а "+w9F6zLD2avTt9fj8aM="
на PHP. Очевидно, что base64 работает одинаково, поскольку результат кодирования исходной строки одинаков, поэтому единственная проблема заключается в шифровании AES, я полагаю, что это один и тот же алгоритм, реализованный на другой платформе, почему результаты отличаются?
ИЗМЕНИТЬ:
Я обнаружил проблему: MCRYPT_RIJNDAEL_256 не эквивалентен AES_256.
Проверьте это: https://stackoverflow.com/a/17249813/402197
MCRYPT_RIJNDAEL_256
иAES_256
не одно и то же. - person Shane   schedule 06.12.2013