AES是目前最常用的对称加密算法,其应用范围非常广泛,如数据安全传输、文件加密等。PHP作为一种常用的语言,在实现AES加密、解密时也提供了很好的支持。
PHP实现的AES加密、解密封装类与用法示例
简介
AES是目前最常用的对称加密算法,其应用范围非常广泛,如数据安全传输、文件加密等。PHP作为一种常用的语言,在实现AES加密、解密时也提供了很好的支持。
本文将介绍如何使用PHP实现AES加解密,并封装成简便的类文件。同时,本文会提供两个用例,让读者更好地了解如何使用该功能库。
实现AES加密、解密
PHP中提供了openssl扩展,可用于实现AES加解密。下面分别介绍加密和解密的过程:
AES加密
/**
* 对数据进行AES加密
* @param string $data 需要加密的数据
* @param string $key 密钥
* @param string $iv 向量
* @return string
*/
function aesEncrypt($data, $key, $iv)
{
$data = openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
return base64_encode($data);
}
上述代码实现了AES加密过程。在这里,使用openssl_encrypt()
函数实现加密功能,该函数的前四个参数分别为加密算法、key、数据、flags。其中,padding和向量都是可以通过flag选项提供的。
AES解密
/**
* 对数据进行AES解密
* @param string $data 需要解密的数据
* @param string $key 密钥
* @param string $iv 向量
* @return string
*/
function aesDecrypt($data, $key, $iv)
{
$data = base64_decode($data);
return openssl_decrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
}
上述代码实现了AES解密过程。与加密类似,使用openssl_decrypt()
函数实现解密,同样也可以指定padding和向量等参数。
封装成类文件
有了上面的加解密过程,我将其封装成了类文件Aes.php
,方便实际开发过程中直接调用。
class Aes
{
/**
* 加密
* @param string $data 需要加密的数据
* @param string $key 密钥
* @param string $iv 向量
* @return string
*/
public static function aesEncrypt($data, $key, $iv)
{
$data = openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
return base64_encode($data);
}
/**
* 解密
* @param string $data 需要解密的数据
* @param string $key 密钥
* @param string $iv 向量
* @return string
*/
public static function aesDecrypt($data, $key, $iv)
{
$data = base64_decode($data);
return openssl_decrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
}
}
用例
用法示例一
加密数据:hello world
密钥:myaeskey12345
向量:1234567890123456
$data = "hello world";
$key = "myaeskey12345";
$iv = "1234567890123456";
$encryptData = Aes::aesEncrypt($data, $key, $iv); // 加密后数据
$decryptData = Aes::aesDecrypt($encryptData, $key, $iv); // 解密后数据
用法示例二
加密数据:{"name":"user1","age":18}
密钥:myaeskey67890
向量:9876543210987654
$data = '{"name":"user1","age":18}';
$key = "myaeskey67890";
$iv = "9876543210987654";
$encryptData = Aes::aesEncrypt($data, $key, $iv); // 加密后数据
$decryptData = Aes::aesDecrypt($encryptData, $key, $iv); // 解密后数据
在这里,用例一和用例二分别展示了如何应用于加密数据和解密数据中,并指定密钥和向量。
本文标题为:PHP实现的AES加密、解密封装类与用法示例


基础教程推荐
- php+mysql开发的最简单在线题库(在线做题系统)完整案例 2023-01-04
- php去除deprecated的实例方法 2022-09-02
- php生成短网址/短链接原理和用法实例分析 2023-04-20
- Laravel 解决composer相关操作提示php相关异常的问题 2023-03-08
- PHP采用get获取url汉字出现乱码的解决方法 2024-03-28
- PHP laravel使用自定义邮件类实现发送邮件 2023-07-03
- PHP字符串函数系列之nl2br(),在字符串中的每个新行 (\n) 之前插入 HTML 换行符br 2024-03-28
- PHP基于反射机制实现自动依赖注入的方法详解 2022-10-02
- php如何获取当前日期和星期 2024-12-06
- Laravel修改验证提示信息为中文的示例 2023-03-08