openssl内置PKCS5Padding,无需额外操作
需要注意:
AES的密钥长度与加密方式选择
- AES-128 使用128比特(16字节)密钥
- AES-192 使用192比特(24字节)密钥
- AES-256 使用256比特(32字节)密钥
class CryptAES
{
/**
* var string $method 加解密方法,可通过openssl_get_cipher_methods()获得
*/
protected $method;
/**
* var string $secret_key 加解密的密钥
*/
protected $secret_key;
/**
* var string $iv 加解密的向量,有些方法需要设置比如CBC
*/
protected $iv;
/**
* var string $options (不知道怎么解释,目前设置为0没什么问题)
*/
protected $options;
/**
* 构造函数
*
* @param string $key 密钥
* @param string $method 加密方式
* @param string $iv iv向量
* @param mixed $options 还不是很清楚
*
*/
public function __construct($key, $method = 'AES-128-ECB', $iv = '', $options = 0)
{
// key是必须要设置的
$this->secret_key = isset($key) ? $key : exit('key为必须项');
$this->method = $method;
$this->iv = $iv;
$this->options = $options;
}
/**
* 加密方法,对数据进行加密,返回加密后的数据
*
* @param string $data 要加密的数据
*
* @return string
*
*/
public function encrypt($data)
{
return openssl_encrypt($data, $this->method, $this->secret_key, $this->options, $this->iv);
}
/**
* 解密方法,对数据进行解密,返回解密后的数据
*
* @param string $data 要解密的数据
*
* @return string
*
*/
public function decrypt($data)
{
return openssl_decrypt($data, $this->method, $this->secret_key, $this->options, $this->iv);
}
}
本文详细介绍了如何在PHP7中利用openssl扩展进行AES/ECB/PKCS5Padding加密。重点强调了加密过程中AES密钥长度的选择,包括AES-128(16字节密钥)、AES-192(24字节密钥)和AES-256(32字节密钥)。由于openssl内置了PKCS5Padding,因此在加密时无需额外处理填充问题。
914

被折叠的 条评论
为什么被折叠?



