当前位置:首页 > PHP

php 实现aes

2026-02-14 19:28:05PHP

PHP 实现 AES 加密解密

PHP 提供了内置函数支持 AES 加密算法,常用的模式包括 CBC、ECB 等。以下示例展示如何使用 OpenSSL 扩展实现 AES-256-CBC 加密解密。

加密示例

$plaintext = "需要加密的数据";
$key = openssl_random_pseudo_bytes(32); // AES-256 需要 32 字节密钥
$iv = openssl_random_pseudo_bytes(16); // IV 长度 16 字节

$ciphertext = openssl_encrypt(
    $plaintext,
    'aes-256-cbc',
    $key,
    OPENSSL_RAW_DATA,
    $iv
);

// 通常需要 base64 编码便于存储传输
$encoded = base64_encode($iv.$ciphertext);

解密示例

$decoded = base64_decode($encoded);
$iv = substr($decoded, 0, 16);
$ciphertext = substr($decoded, 16);

$plaintext = openssl_decrypt(
    $ciphertext,
    'aes-256-cbc',
    $key,
    OPENSSL_RAW_DATA,
    $iv
);

注意事项

密钥长度需与算法匹配:AES-128 对应 16 字节,AES-192 对应 24 字节,AES-256 对应 32 字节

IV 应当随机生成且每次加密不同,不要硬编码 IV

存储或传输时需要将 IV 和密文一起保存,通常采用 IV+密文的拼接方式

兼容处理

如需与其它语言交互,需确保双方使用相同的:

  • 密钥长度
  • 加密模式(如 CBC)
  • 填充方式(OpenSSL 默认 PKCS7)
  • 字符编码(通常 UTF-8)

php 实现aes

标签: phpaes
分享给朋友:

相关文章

php实现购物车

php实现购物车

PHP实现购物车功能 购物车功能是电商网站的核心模块之一,通常涉及商品添加、删除、数量修改和结算等操作。以下是使用PHP实现购物车功能的几种方法。 使用Session存储购物车数据 Session…

php实现验证码

php实现验证码

PHP实现验证码的方法 使用GD库生成验证码 GD库是PHP中处理图像的扩展,可用于生成验证码图片。 <?php session_start(); $width = 120; $height…

php实现socket

php实现socket

PHP 实现 Socket 通信 PHP 可以通过 socket 扩展实现网络通信,支持 TCP/UDP 协议。以下是实现 Socket 通信的核心步骤和代码示例。 创建 TCP 服务器 //…

php实现栈

php实现栈

栈的基本概念 栈(Stack)是一种遵循后进先出(LIFO)原则的数据结构。核心操作包括: push:元素入栈。 pop:元素出栈(返回并移除栈顶元素)。 peek:查看栈顶元素…

php购物车实现

php购物车实现

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

php实现排序

php实现排序

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