Я использую open-ssl в проекте и хочу зашифровать имя и фамилию пользователей. Я обнаружил странное поведение open-ssl: шифруются только строки, содержащие более 15 символов. Это моя вина или что-то не задокументированное?
<?php
$cipher = 'aes-256-xts';
$privateKey = 'LOOK';
$stringToEncrypt = "Luisa 111 111 11";
$ivLength = openssl_cipher_iv_length($cipher);
$iv = openssl_random_pseudo_bytes($ivLength);
$encryptedData = openssl_encrypt($stringToEncrypt, $cipher, $privateKey, 0, $iv) . ":" . base64_encode($iv);
list($encryptedString, $iv) = explode(':', $encryptedData, 2);
$decryptedData = openssl_decrypt($encryptedString, $cipher, $privateKey, 0, base64_decode($iv));
Кто-нибудь знает решение моей проблемы?
Заранее спасибо!
Кроме того, убедитесь, что ваш закрытый ключ составляет 32 необработанных байта. Ни больше ни меньше.
@IncredibleHat ... с aes-256-xts $ encryptedData содержит только iv, но, очевидно, ничего не зашифровывается, если незашифрованное значение содержит 15 или меньше символов. Никаких ошибок или уведомлений не выводится.
Благодаря @IncredibleHat - ключом к разгадке было изменение шифра на aes-256-cbc - теперь openssl_encrypt работает, как задумано. Я могу зашифровать данные даже одним символом!






Решение: изменение шифра на aes-256-cbc позволяет шифровать строки только одним символом.
Переключитесь на
aes-256-cbc. Однако мне любопытно, что вы подразумеваете под 15+ шифрованием. Что произойдет, если в нем 14 символов? Шифрует, но не расшифровывает, или выдает незашифрованное значение, или делает ошибку, или ...