RNCryptorを使用して、iOS 側で AES256 暗号化を実行し、PHP のリモート サイトで AES256 復号化を実行しようとしています。しかし、phpで正しい復号化されたデータを取得できません。私が間違っていることがあれば、レビューを手伝ってください。
以下はiOS用の私のコードです。
NSString *key = @"1234567890123456789012";
NSData *encryptedData = [RNEncryptor encryptData:data
withSettings:kRNCryptorAES256Settings
password:key
error:&error];
次に、encryptedData を PHP のサーバーに投稿します。以下は私のPHPコードです。
$key ="1234567890123456789012" //32-bit key
$username = aes256Decrypt ($key, $username);
function aes256Decrypt($key, $data) {
if(32 !== strlen($key)) $key = hash('SHA256', $key, true);
$data = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC,
str_repeat("\0", 16));
$padding = ord($data[strlen($data) - 1]);
$result = substr($data, 0, -$padding);
return substr($data, 0, -$padding);
}