Я могу зашифровать данные, но не могу расшифровать

Я могу успешно зашифровать переданные данные, но, к сожалению, не могу их расшифровать. Что не так с моим decrypt() функционировать? Может быть, это что-то с моим вектором инициализации (iv). Вот мой код:

function pad($data, $size) {
$length = $size - strlen($data) % $size;
return $data . str_repeat(chr($length), $length);
}

function unpad($data) {
return substr($data, 0, -ord($data[strlen($data) - 1]));
}

//CORRECT ENCRYPTION METHOD
function encrypt($data) {
$key = "SiadajerSiadajer";
$iv_size = 16;
$iv = openssl_random_pseudo_bytes($iv_size, $strong);
$encryptedData = openssl_encrypt(pad($data, 16), 'AES-256-CBC', $key,   OPENSSL_RAW_DATA, $iv);
$joinedData = hex2bin(bin2hex($iv).bin2hex($encryptedData));
$encodedJoinedData = base64_encode($joinedData);
return $encodedJoinedData;
}

//WRONG DECRYPTION FUNCTION
function decrypt($encodedJoinedData){
$key = "SiadajerSiadajer";
$DecodedData = base64_decode($encodedJoinedData);
$size = strlen($DecodedData);
$cipheredsize = $size - 16;
$iv = substr($DecodedData, 0, 16);
$halfDecryptedData = substr($DecodedData, 16, $size);
$decryptedData = openssl_decrypt(unpad($halfDecryptedData, 16), 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv);
return $decryptedData;
}

$test = encrypt("sssss");
print $test;
$test2 = decrypt($test);
print $test2;

0

Решение

в encryptметод заменить линию

$joinedData = hex2bin(bin2hex($iv).bin2hex($encryptedData));

с

$joinedData = $iv.$encryptedData;

потому что преобразования в предыдущем выражении не нужны. Эта замена не меняет результат.

Возможное решение для части дешифрования может быть:

function decrypt($encodedJoinedData) {
$joinedData = base64_decode($encodedJoinedData);
$iv = substr($joinedData, 0, 16);
$encryptedData = substr($joinedData, 16);
$key = "SiadajerSiadajer";
$decryptedData = openssl_decrypt($encryptedData, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv);
$unpaddedData = unpad($decryptedData);
return $unpaddedData;
}
1

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector