實現 PHP 配置數據庫文件加密可以通過以下步驟進行:
$key = openssl_random_pseudo_bytes(32);
file_put_contents('config.key', $key);
$config = [
'host' => 'localhost',
'username' => openssl_encrypt('myusername', 'AES-256-CBC', $key),
'password' => openssl_encrypt('mypassword', 'AES-256-CBC', $key),
'database' => 'mydatabase',
];
file_put_contents('config.php', '<?php return ' . var_export($config, true) . ';');
$config = include 'config.php';
$dbUsername = openssl_decrypt($config['username'], 'AES-256-CBC', $key);
$dbPassword = openssl_decrypt($config['password'], 'AES-256-CBC', $key);
// 使用解密后的用戶名和密碼連接數據庫
$db = new PDO('mysql:host=' . $config['host'] . ';dbname=' . $config['database'], $dbUsername, $dbPassword);
重要提示:確保密鑰文件(config.key)和配置文件(config.php)存放在安全的位置,不要讓它們可以被公開訪問。