在 PHP 中,你可以使用加密算法和相关的扩展库来进行数据加密和解密。以下是使用 PHP 进行数据加密和解密的基本示例:
使用 OpenSSL 扩展进行加密和解密:
-
加密:
php<?php $data = "Hello, World!"; $key = openssl_random_pseudo_bytes(32); // 生成随机密钥 $iv = openssl_random_pseudo_bytes(16); // 生成随机初始化向量 $encrypted = openssl_encrypt($data, 'aes-256-cbc', $key, 0, $iv); // 存储 $key 和 $iv 以便后续解密 echo "Encrypted Data: $encrypted\n"; ?>
-
解密:
php<?php $encrypted = "encrypted-data"; // 用加密后的数据替换 // 从存储的地方获取 $key 和 $iv $decrypted = openssl_decrypt($encrypted, 'aes-256-cbc', $key, 0, $iv); echo "Decrypted Data: $decrypted\n"; ?>
使用 Sodium 扩展进行加密和解密(PHP 7.2+):
-
加密:
php<?php $data = "Hello, World!"; $key = sodium_crypto_secretbox_keygen(); // 生成随机密钥 $nonce = random_bytes(SODIUM_CRYPTO_SECRETBOX_NONCEBYTES); // 生成随机 nonce $encrypted = sodium_crypto_secretbox($data, $nonce, $key); // 存储 $key 和 $nonce 以便后续解密 echo "Encrypted Data: " . base64_encode($encrypted) . "\n"; ?>
-
解密:
php<?php $encrypted = base64_decode("encrypted-data"); // 用加密后的数据替换 // 从存储的地方获取 $key 和 $nonce $decrypted = sodium_crypto_secretbox_open($encrypted, $nonce, $key); echo "Decrypted Data: $decrypted\n"; ?>
确保在实际应用中,密钥(key)和初始化向量(iv/nonce)等敏感信息需要进行安全存储,不应该直接硬编码在代码中。密钥管理和安全存储是确保加密系统安全的关键。