欢迎来到全国社交动力网络科技有限公司
建站资讯

当前位置: 首页 > 建站资讯 > 建站教程 > PHP教程

PHP命令怎么执行加密操作_PHP命令行加密解密函数使用

作者:免费建APP 来源:php培训班时间日期:2025-10-19
使用OpenSSL或Sodium在PHP中实现加密解密,推荐Sodium更安全;通过$argv处理命令行参数,结合AES-256-CBC或crypto_secretbox进行加解密操作,密钥应从环境变量读取以保障安全。

php命令怎么执行加密操作_php命令行加密解密函数使用

在PHP中执行加密操作,通常使用内置的加密函数或扩展,比如 OpenSSL、Mcrypt(已废弃)或 Sodium。通过命令行运行PHP脚本进行加密解密非常实用,尤其在自动化处理敏感数据时。下面介绍几种常用方式和示例。

使用OpenSSL进行加密解密

OpenSSL是PHP中最常用的加密扩展,支持多种加密算法,如AES-256-CBC。

加密示例:

<?phpfunction encrypt($data, $key) {    $method = 'AES-256-CBC';    $iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length($method));    $encrypted = openssl_encrypt($data, $method, $key, 0, $iv);    return base64_encode($iv . $encrypted);}// 命令行调用:php encrypt.php$key = 'your-32-byte-secret-key-here!!!!'; // 必须32字节$data = 'Hello, this is secret!';echo "加密结果: " . encrypt($data, $key) . "\n";?>
登录后复制

解密示例:

立即学习“PHP免费学习笔记(深入)”;

<?phpfunction decrypt($raw, $key) {    $method = 'AES-256-CBC';    $data = base64_decode($raw);    $ivLength = openssl_cipher_iv_length($method);    $iv = substr($data, 0, $ivLength);    $encrypted = substr($data, $ivLength);    return openssl_decrypt($encrypted, $method, $key, 0, $iv);}$key = 'your-32-byte-secret-key-here!!!!';$encryptedData = $argv[1] ?? '';if ($encryptedData) {    echo "解密结果: " . decrypt($encryptedData, $key) . "\n";} else {    echo "请传入加密字符串\n";}?>
登录后复制

命令行使用方法:

度加剪辑 度加剪辑

度加剪辑(原度咔剪辑),百度旗下AI创作工具

度加剪辑63 查看详情 度加剪辑 加密:php encrypt.php 解密:php decrypt.php [加密字符串]

使用Sodium(推荐,更安全)

Sodium 是 PHP 7.2+ 推荐的现代加密库,比 OpenSSL 更简单且更安全。

<?phpif (!extension_loaded('sodium')) {    die('Sodium扩展未启用');}$key = sodium_crypto_secretbox_keygen();$nonce = random_bytes(SODIUM_CRYPTO_SECRETBOX_NONCEBYTES);$message = 'This is a secret message';$ciphertext = sodium_crypto_secretbox($message, $nonce, $key);$encoded = base64_encode($nonce . $ciphertext);echo "加密后: " . $encoded . "\n";// 解密$decoded = base64_decode($encoded);$dnonce = substr($decoded, 0, SODIUM_CRYPTO_SECRETBOX_NONCEBYTES);$dtext = substr($decoded, SODIUM_CRYPTO_SECRETBOX_NONCEBYTES);try {    $decrypted = sodium_crypto_secretbox_open($dtext, $dnonce, $key);    echo "解密后: " . $decrypted . "\n";} catch (Exception $e) {    echo "解密失败\n";}?>
登录后复制

Sodium需要确保PHP环境已启用sodium扩展(通常默认启用)。

命令行参数处理技巧

在写加密脚本时,可通过$argv读取命令行参数,实现灵活调用。

$argv[0] 是脚本名 $argv[1], $argv[2]... 是传入的参数 例如:php crypto.php encrypt "data" 或 php crypto.php decrypt [token]

可结合switch判断操作类型,提升脚本实用性。

基本上就这些。选择OpenSSL或Sodium根据环境决定,注意密钥保管和IV随机性,避免硬编码密钥到脚本中。生产环境建议从环境变量或配置文件安全读取。

以上就是PHP命令怎么执行加密操作_PHP命令行加密解密函数使用的详细内容,更多请关注php中文网其它相关文章!

标签: php教程 800
上一篇: PHP如何删除数据库记录_PHP实现mysql数据删除的详细步骤
下一篇: 教你免费获得网址加V绿钩认证,解决"安全性未知请,谨慎访问"

推荐建站资讯

更多>