当前位置:首页 > PHP

php实现aes加密

2026-02-27 22:37:34PHP

AES 加密实现方法

在 PHP 中实现 AES 加密可以使用 openssl_encrypt 函数。AES(Advanced Encryption Standard)是一种对称加密算法,支持不同的密钥长度(128、192、256 位)和加密模式(如 CBC、ECB 等)。

基本加密函数

function aesEncrypt($data, $key, $iv) {
    $method = 'AES-256-CBC'; // 加密方法和模式
    $options = OPENSSL_RAW_DATA;
    $encrypted = openssl_encrypt($data, $method, $key, $options, $iv);
    return base64_encode($encrypted); // 返回 Base64 编码的加密数据
}

基本解密函数

function aesDecrypt($encryptedData, $key, $iv) {
    $method = 'AES-256-CBC';
    $options = OPENSSL_RAW_DATA;
    $decrypted = openssl_decrypt(base64_decode($encryptedData), $method, $key, $options, $iv);
    return $decrypted;
}

使用示例

$key = 'your-secret-key-32-bytes-long'; // 密钥长度必须符合所选 AES 版本(如 AES-256 需要 32 字节)
$iv = 'initialization-vector'; // 初始化向量(IV),通常为 16 字节
$data = 'Hello, AES Encryption!';

$encrypted = aesEncrypt($data, $key, $iv);
echo "Encrypted: " . $encrypted . "\n";

$decrypted = aesDecrypt($encrypted, $key, $iv);
echo "Decrypted: " . $decrypted . "\n";

密钥和 IV 生成

为了增强安全性,建议使用随机生成的密钥和 IV。

生成随机密钥和 IV

$key = openssl_random_pseudo_bytes(32); // 32 字节密钥(AES-256)
$iv = openssl_random_pseudo_bytes(16); // 16 字节 IV

注意事项

  • 密钥长度必须与 AES 版本匹配:AES-128 需要 16 字节密钥,AES-192 需要 24 字节密钥,AES-256 需要 32 字节密钥。
  • IV 长度通常为 16 字节(128 位),且每次加密时应使用不同的 IV。
  • 存储或传输密钥和 IV 时需确保安全,避免泄露。

通过以上方法,可以在 PHP 中轻松实现 AES 加密和解密功能。

php实现aes加密

标签: phpaes
分享给朋友:

相关文章

php实现树

php实现树

PHP实现树结构的方法 在PHP中实现树结构通常可以通过递归或迭代的方式完成。以下是几种常见的实现方法: 递归实现树结构 递归是处理树结构的自然方式,尤其适用于具有未知深度的树。 class…

php实现递归

php实现递归

递归的基本概念 递归是一种函数调用自身的技术,适用于解决可以分解为相同子问题的问题。在PHP中,递归需要明确的终止条件(基线条件),否则会导致无限循环。 递归实现阶乘 阶乘是经典的递归案例,n!…

php实现定时任务

php实现定时任务

PHP 实现定时任务的几种方法 在 PHP 中实现定时任务可以通过多种方式完成,具体选择取决于项目需求和服务器环境。以下是常见的实现方法: 使用 Cron 任务 Cron 是 Linux 系统中常用…

php购物车实现

php购物车实现

PHP购物车实现方法 使用PHP实现购物车功能可以通过多种方式完成,以下是几种常见的实现方法: Session存储购物车数据 利用PHP的$_SESSION超全局变量存储购物车数据是最简单的方法。用…

php实现排序

php实现排序

PHP 数组排序方法 PHP 提供了多种内置函数用于数组排序,适用于不同的排序需求。以下是常见的排序方法: 按值升序排序 sort() 函数对数组按值升序排序,重置键名(索引数组适用): $n…

php实现mysql

php实现mysql

PHP 连接 MySQL 的基本方法 PHP 提供了多种方式与 MySQL 数据库进行交互,以下是最常用的几种方法。 使用 MySQLi 扩展 MySQLi 是 MySQL 的改进扩展,支持面向对…