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

絕刀狂花
发布: 2025-10-19 13:55:01
原创
988人浏览过
使用OpenSSL或Sodium在PHP中实现加密解密,推荐Sodium更安全;通过$argv处理命令行参数,结合AES-256-CBC或crypto_secretbox进行加解密操作,密钥应从环境变量读取以保障安全。

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

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

使用OpenSSL进行加密解密

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

加密示例:

<?php
function 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免费学习笔记(深入)”;

<?php
function 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 更简单且更安全。

<?php
if (!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速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号