在 PHP 中,可以使用 openssl_encrypt
和 openssl_decrypt
函数对文件内容进行加密和解密。以下是一个简单的示例,展示了如何使用这些函数对文件内容进行加密和解密。
首先,创建一个名为 encrypt_file.php
的文件,其中包含以下内容:
$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
的文件,其中包含以下内容:
$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 加密算法,你可以根据需要更改为其他加密算法。同时,确保在实际应用中使用安全的密钥管理方法,而不是将密钥和初始化向量硬编码到脚本中。