在 PHP 中,可以使用 openssl_encrypt
和 openssl_decrypt
函数对文件内容进行加密和解密。以下是一个简单的示例,展示了如何使用这些函数对文件内容进行加密和解密。
首先,创建一个名为 encrypt_file.php
的文件,其中包含以下内容:
<?php
function encryptFile($inputFile, $outputFile, $method = 'AES-256-CBC')
{
// 读取文件内容
$plaintext = file_get_contents($inputFile);
// 生成随机密钥和初始化向量
$key = openssl_random_pseudo_bytes(openssl_cipher_iv_length($method));
$iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length($method));
// 加密文件内容
$ciphertext = openssl_encrypt($plaintext, $method, $key, 0, $iv);
// 将密钥和初始化向量写入文件
file_put_contents($outputFile . '.key', $key);
file_put_contents($outputFile . '.iv', $iv);
// 将加密后的内容写入文件
file_put_contents($outputFile, $ciphertext);
}
$inputFile = 'input.txt';
$outputFile = 'output.enc';
encryptFile($inputFile, $outputFile);
echo "File encrypted successfully!";
?>
接下来,创建一个名为 decrypt_file.php
的文件,其中包含以下内容:
<?php
function decryptFile($inputFile, $outputFile, $method = 'AES-256-CBC')
{
// 读取加密后的文件内容和密钥、初始化向量
$ciphertext = file_get_contents($inputFile);
$key = file_get_contents($inputFile . '.key');
$iv = file_get_contents($inputFile . '.iv');
// 解密文件内容
$plaintext = openssl_decrypt($ciphertext, $method, $key, 0, $iv);
// 将解密后的内容写入文件
file_put_contents($outputFile, $plaintext);
}
$inputFile = 'output.enc';
$outputFile = 'output.txt';
decryptFile($inputFile, $outputFile);
echo "File decrypted successfully!";
?>
现在,你可以使用 encrypt_file.php
对文件进行加密,然后使用 decrypt_file.php
对加密后的文件进行解密。请注意,这个示例使用了 AES-256-CBC 加密算法,你可以根据需要更改为其他加密算法。同时,确保在实际应用中使用安全的密钥管理方法,而不是将密钥和初始化向量硬编码到脚本中。