在PHP中使用AES进行加密和解密

简介: 在PHP中使用AES进行加密和解密

PHP 中使用 AES(Advanced Encryption Standard)进行加密和解密通常涉及使用 OpenSSL 扩展。以下是使用 PHP 进行 AES 加密和解密的基本原理:

 

### AES 加密:

 

1. **选择加密算法和模式**:

  - AES 是一种对称加密算法,常用的模式包括 ECB、CBC、CFB、OFB 等。

 

2. **生成密钥和初始化向量(IV)**:

  - 生成一个密钥和一个初始化向量(IV),密钥通常是一个固定长度的字符串,IV 是用于增加加密强度的随机值。

 

3. **加密数据**:

  - 使用 OpenSSL 函数(如 `openssl_encrypt`)对明文数据进行加密。

  - 提供明文数据、加密算法、密钥、初始化向量和选项等参数。

  - 例如:`openssl_encrypt($data, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv)`。

 

4. **获取加密后的密文**:

  - 加密后的数据将以二进制格式返回,通常可以使用 Base64 编码将其转换为可打印字符。

 

### AES 解密:

 

1. **解密数据**:

  - 使用 OpenSSL 函数(如 `openssl_decrypt`)对密文数据进行解密。

  - 提供密文数据、加密算法、密钥、初始化向量和选项等参数。

  - 例如:`openssl_decrypt($encryptedData, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv)`。

 

2. **获取解密后的明文**:

  - 解密后的数据将以二进制格式返回,可能需要根据具体情况进行进一步处理。

 

PHP 中使用 OpenSSL 扩展可以很容易地实现 AES 加密和解密。以下是一个简单的示例代码,演示如何在 PHP 中使用 AES-256-CBC 加密和解密数据:

 

```php
<?php
function encryptAES($data, $key, $iv) {
    $encrypted = openssl_encrypt($data, 'AES-256-CBC', $key, 0, $iv);
    return base64_encode($encrypted);
}
 
function decryptAES($data, $key, $iv) {
    $decrypted = openssl_decrypt(base64_decode($data), 'AES-256-CBC', $key, 0, $iv);
    return $decrypted;
}
 
$key = 'YourSecretKey'; // 密钥,必须是 16、24 或 32 字符长度的字符串
$iv = 'YourIV1234567890'; // 初始化向量,必须是 16 字符长度的字符串
$data = 'Hello, World!';
 
$encryptedData = encryptAES($data, $key, $iv);
echo "Encrypted Data: $encryptedData\n";
 
$decryptedData = decryptAES($encryptedData, $key, $iv);
echo "Decrypted Data: $decryptedData\n";
?>
```

 

在上面的示例中:

- `encryptAES` 函数用于对数据进行 AES 加密,返回 base64 编码后的密文。

- `decryptAES` 函数用于对密文进行 AES 解密,返回解密后的明文。

- `key` 是用于加密和解密的密钥,必须是 16、24 或 32 字符长度的字符串。

- `iv` 是用于 AES 加密的初始化向量,必须是 16 字符长度的字符串。

- `$data` 是要加密的原始数据。

 

请确保在实际应用中妥善保管密钥和初始化向量,并根据需求选择合适的密钥长度和加密模式。

相关文章
|
4天前
|
Linux 数据安全/隐私保护 Windows
aes加密在linux下会生成随机key的解决办法
aes加密在linux下会生成随机key的解决办法
20 2
|
4天前
|
存储 安全 算法
【PHP开发专栏】PHP加密与解密技术
【4月更文挑战第29天】本文探讨了PHP中的加密解密技术,涵盖基本概念如对称加密(AES、DES)、非对称加密(RSA、DSA)和哈希函数(MD5、SHA)。PHP提供内置函数支持加密,如`openssl_encrypt`、`openssl_pkey_new`、`hash`和`password_hash`。文章强调了最佳实践,如使用安全密钥、密钥管理和HTTPS,并给出用户注册登录的加密实战示例。通过理解和应用这些技术,开发者能增强Web应用的数据安全性。
|
4天前
|
安全 PHP 开发工具
php代码加密 php-screw-plus
php代码加密 php-screw-plus
38 0
|
4天前
|
算法 PHP 数据安全/隐私保护
【实战】PHP代码逆向工具,轻松还原goto加密语句的神器!
`goto解密工具`是一款针对PHP的在线神器,能有效解密和还原goto加密代码,提升代码可读性和可维护性。支持单文件及50M压缩包一键解密,提供全效解决方案。通过实际案例展示了解密报错和理解复杂代码的能力,是PHP开发者解决goto难题的得力助手。立即体验:[在线PHP解密大师](https://copy.kaidala.com/dala/goto/index.html)。
30 1
|
4天前
|
PHP 数据安全/隐私保护
PHP在线加密系统网站源码
这个是sg的加密,免费可用(目前)并不会收费 源码说明:下载直接上传即可
26 1
PHP在线加密系统网站源码
|
PHP Android开发 数据安全/隐私保护
【PHP】android、ios、php之间AES加密解密
【PHP】android、ios、php之间AES加密解密
518 0
|
8月前
|
关系型数据库 MySQL PHP
PHP 原生操作 Mysql
PHP 原生操作 Mysql
84 0
|
8月前
|
关系型数据库 MySQL 数据库连接
PHP 原生连接 Mysql
PHP 原生连接 Mysql
111 0
|
8月前
|
关系型数据库 MySQL Unix
PHP MySql 安装与连接
PHP MySql 安装与连接
138 0
|
4天前
|
关系型数据库 MySQL PHP