当前位置:首页 > PHP

php实现aes加密

2026-02-13 23:42:27PHP

PHP实现AES加密的方法

AES(Advanced Encryption Standard)是一种常用的对称加密算法。在PHP中,可以通过openssl_encryptopenssl_decrypt函数实现AES加密和解密。

加密函数示例

以下是一个使用AES-256-CBC模式加密的PHP函数示例:

php实现aes加密

function encryptAES($data, $key, $iv) {
    $cipher = "aes-256-cbc";
    $options = OPENSSL_RAW_DATA;
    $encrypted = openssl_encrypt($data, $cipher, $key, $options, $iv);
    return base64_encode($encrypted);
}

解密函数示例

对应的解密函数如下:

function decryptAES($encryptedData, $key, $iv) {
    $cipher = "aes-256-cbc";
    $options = OPENSSL_RAW_DATA;
    $decrypted = openssl_decrypt(base64_decode($encryptedData), $cipher, $key, $options, $iv);
    return $decrypted;
}

使用方法

$key = "thisisasecretkey1234567890123456"; // 32字节密钥
$iv = "thisisanivvector12"; // 16字节IV向量
$data = "Hello, World!";

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

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

注意事项

密钥长度必须与所选算法匹配:

php实现aes加密

  • AES-128-CBC需要16字节密钥
  • AES-192-CBC需要24字节密钥
  • AES-256-CBC需要32字节密钥

IV向量必须是16字节长度,且应该为每个加密操作生成唯一的IV。在实际应用中,IV可以随机生成并与加密数据一起存储:

$iv = openssl_random_pseudo_bytes(16);

安全建议

为了提高安全性,建议:

  • 使用强随机数生成器创建密钥和IV
  • 定期轮换加密密钥
  • 使用HMAC验证密文的完整性
  • 考虑使用PHP 7.2+的现代加密函数如sodium_crypto_secretbox

标签: phpaes
分享给朋友:

相关文章

php实现分页

php实现分页

PHP实现分页的基本方法 使用原生PHP实现分页功能需要结合数据库查询和HTML展示。以下是核心实现步骤: 数据库查询与分页逻辑 // 连接数据库 $conn = new mysqli('lo…

php实现文件上传

php实现文件上传

PHP 文件上传实现方法 在 PHP 中实现文件上传需要处理 HTML 表单和服务器端脚本。以下是详细步骤: 创建 HTML 表单 使用 enctype="multipart/form-data"…

php实现websocket

php实现websocket

PHP 实现 WebSocket WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。PHP 可以通过多种方式实现 WebSocket 功能,以下是几种常见的方法: 使用 Ratc…

php 路由实现

php 路由实现

PHP 路由实现方法 在 PHP 中实现路由功能有多种方式,以下是几种常见的实现方法: 使用原生 PHP 实现 通过解析 URL 并匹配对应的控制器和动作: $request = $_SERVER…

php实现搜索

php实现搜索

PHP实现搜索功能的方法 在PHP中实现搜索功能通常涉及数据库查询和用户输入的匹配。以下是几种常见的实现方式: 使用MySQL LIKE语句 通过简单的LIKE语句实现基础搜索: $searc…

php 实现接口

php 实现接口

PHP 实现接口的方法 在 PHP 中,接口(Interface)用于定义一组方法的规范,而不包含具体的实现。类可以实现(implement)接口,并必须实现接口中定义的所有方法。 定义接口 接口…