PHP7如何实现AESECBPKCS5Padding加密,还有其他更复杂的加密方式吗?
- 内容介绍
- 文章标签
- 相关推荐
本文共计477个文字,预计阅读时间需要2分钟。
本章节为大家介绍PHP7实现AES/ECB/PKCS5Padding加密的方法。以下是一定的参考价值,如有需要的朋友可参考,希望对大家有所帮助。
phpclass CryptAES{ /** * 加解密方法 * * @param string $method 加解密方式 * @param string $data 待加密/解密的数据 * @param string $key 密钥 * @return string 加密/解密后的数据 */ public function encryptDecrypt($method, $data, $key) { // 设置密钥和向量 $key=substr(hash('sha256', $key, true), 0, 32); $iv=substr(hash('sha256', $key . microtime(), true), 0, 16);
// 初始化加密环境 $encrypt=openssl_init_cipher_iv($method, $key, $iv);
// 加密或解密数据 $result=openssl_encrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv) ?: openssl_decrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv);
// 清理资源 openssl_free_cipher($encrypt);
// 返回结果 return base64_encode($result); }}
本篇文章给大家介绍一下PHP7实现AES/ECB/PKCS5Padding加密的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
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); } }
推荐学习:php视频教程
本文共计477个文字,预计阅读时间需要2分钟。
本章节为大家介绍PHP7实现AES/ECB/PKCS5Padding加密的方法。以下是一定的参考价值,如有需要的朋友可参考,希望对大家有所帮助。
phpclass CryptAES{ /** * 加解密方法 * * @param string $method 加解密方式 * @param string $data 待加密/解密的数据 * @param string $key 密钥 * @return string 加密/解密后的数据 */ public function encryptDecrypt($method, $data, $key) { // 设置密钥和向量 $key=substr(hash('sha256', $key, true), 0, 32); $iv=substr(hash('sha256', $key . microtime(), true), 0, 16);
// 初始化加密环境 $encrypt=openssl_init_cipher_iv($method, $key, $iv);
// 加密或解密数据 $result=openssl_encrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv) ?: openssl_decrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv);
// 清理资源 openssl_free_cipher($encrypt);
// 返回结果 return base64_encode($result); }}
本篇文章给大家介绍一下PHP7实现AES/ECB/PKCS5Padding加密的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
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); } }
推荐学习:php视频教程

