Я пытаюсь зашифровать / расшифровать файлы в PHP. Пока что я успешно справляюсь с файлами .txt, но когда дело доходит до .pdf и .doc или .docx, мой код дает сбой, то есть он дает абсурдные результаты. Кто-нибудь может предложить модификацию / альтернативу в моем коде? Заранее спасибо!
Вот функция шифрования
function encryptData($value)
{
$key = "Mary has one cat";
$text = $value;
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $text, MCRYPT_MODE_ECB, $iv);
return $crypttext;
}
Вот функция дешифрования
function decryptData($value)
{
$key = "Mary has one cat";
$crypttext = $value;
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $crypttext, MCRYPT_MODE_ECB, $iv);
return trim($decrypttext);
}
я использовал этот блог чтобы помочь мне зашифровать / расшифровать PDF-файлы на моем локальном компьютере, используя openssl_encrypt
так как mcrypt
устарела в php7.
Сначала вы получаете содержимое файла pdf:
$msg = file_get_contents('example.pdf');
Затем я вызвал функцию шифрования, написанную в посте блога:
$msg_encrypted = my_encrypt($msg, $key);
Затем я открываю файл, в который хочу написать, и пишу новое зашифрованное сообщение:
$file = fopen('example.pdf', 'wb');
fwrite($file, $msg_encrypted);
fclose($file);
Для справки, в случае, если этот блог закрывается, вот функции шифрования и дешифрования из блога:
$key = 'bRuD5WYw5wd0rdHR9yLlM6wt2vteuiniQBqE70nAuhU=';
function my_encrypt($data, $key) {
// Remove the base64 encoding from our key
$encryption_key = base64_decode($key);
// Generate an initialization vector
$iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length('aes-256-cbc'));
// Encrypt the data using AES 256 encryption in CBC mode using our encryption key and initialization vector.
$encrypted = openssl_encrypt($data, 'aes-256-cbc', $encryption_key, 0, $iv);
// The $iv is just as important as the key for decrypting, so save it with our encrypted data using a unique separator (::)
return base64_encode($encrypted . '::' . $iv);
}function my_decrypt($data, $key) {
// Remove the base64 encoding from our key
$encryption_key = base64_decode($key);
// To decrypt, split the encrypted data from our IV - our unique separator used was "::"list($encrypted_data, $iv) = explode('::', base64_decode($data), 2);
return openssl_decrypt($encrypted_data, 'aes-256-cbc', $encryption_key, 0, $iv);
}
Других решений пока нет …