在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` 是要加密的原始数据。

 

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

相关文章
|
3月前
|
算法 安全 数据安全/隐私保护
基于AES的遥感图像加密算法matlab仿真
本程序基于MATLAB 2022a实现,采用AES算法对遥感图像进行加密与解密。主要步骤包括:将彩色图像灰度化并重置大小为256×256像素,通过AES的字节替换、行移位、列混合及轮密钥加等操作完成加密,随后进行解密并验证图像质量(如PSNR值)。实验结果展示了原图、加密图和解密图,分析了图像直方图、相关性及熵的变化,确保加密安全性与解密后图像质量。该方法适用于保护遥感图像中的敏感信息,在军事、环境监测等领域具有重要应用价值。
139 35
|
10月前
|
存储 安全 数据安全/隐私保护
浅谈对称加密(AES与DES)
浅谈对称加密(AES与DES)
156 1
|
7月前
|
Linux PHP 数据安全/隐私保护
2024授权加密系统PHP网站源码
2024授权加密系统PHP网站源码
200 58
|
10月前
|
数据安全/隐私保护
aes之ecb模式的加密解密
aes之ecb模式的加密解密
|
10月前
|
存储 安全 数据安全/隐私保护
安全升级!Python AES加密实战,为你的代码加上一层神秘保护罩
【9月更文挑战第12天】在软件开发中,数据安全至关重要。本文将深入探讨如何使用Python中的AES加密技术保护代码免受非法访问和篡改。AES(高级加密标准)因其高效性和灵活性,已成为全球最广泛使用的对称加密算法之一。通过实战演练,我们将展示如何利用pycryptodome库实现AES加密,包括生成密钥、初始化向量(IV)、加密和解密文本数据等步骤。此外,还将介绍密钥管理和IV随机性等安全注意事项。通过本文的学习,你将掌握使用AES加密保护敏感数据的方法,为代码增添坚实的安全屏障。
307 8
|
9月前
|
安全 测试技术 Go
Python 和 Go 实现 AES 加密算法的技术详解
Python 和 Go 实现 AES 加密算法的技术详解
351 0
|
10月前
|
安全 算法 数据安全/隐私保护
黑客克星!Python加密艺术大公开,AES、RSA双剑合璧,守护你的数字世界
在这个数据泛滥的时代,数字世界既充满了知识,也潜藏安全隐患。Python 作为强大的编程语言,以其独特的加密技术为我们的信息安全保驾护航。本文将介绍 AES 和 RSA 这两种加密算法,揭示它们如何协同工作,保护你的数字世界。AES(高级加密标准)以其高效、安全著称,能将敏感信息转化为难以破解的乱码。Python 的 `pycryptodome` 库让 AES 加密变得简单易行。然而,AES 面临密钥分发难题,此时 RSA(非对称加密算法)便大显身手,通过公钥加密、私钥解密的方式确保密钥传输安全。AES 与 RSA 在 Python 中交织成一道坚不可摧的防护网,共同守护我们的数字世界。
191 0
|
算法 PHP 数据安全/隐私保护
PHP 标准AES加密算法类
分享一个标准PHP的AES加密算法类,其中mcrypt_get_block_size('rijndael-128', 'ecb');,如果在不明白原理的情况下比较容易搞错,可以通过mcrypt_list_algorithms函数查看你需要的加密算法标识。  
976 0
|
3月前
|
关系型数据库 MySQL Linux
查看Linux、Apache、MySQL、PHP版本的技巧
以上就是查看Linux、Apache、MySQL、PHP版本信息的方法。希望这些信息能帮助你更好地理解和使用你的LAMP技术栈。
167 17
|
4月前
|
关系型数据库 MySQL PHP
源码编译安装LAMP(HTTP服务,MYSQL ,PHP,以及bbs论坛)
通过以上步骤,你可以成功地在一台Linux服务器上从源码编译并安装LAMP环境,并配置一个BBS论坛(Discuz!)。这些步骤涵盖了从安装依赖、下载源代码、配置编译到安装完成的所有细节。每个命令的解释确保了过程的透明度,使即使是非专业人士也能够理解整个流程。
96 18