上一篇文章講到利用
mcrypt
對數據進行aes加密的方法,但是不支持php7.1.x版本,今天在stackoverflow上看到同樣的問題,是使用openssl
函數的處理方法,點擊下面的鏈接stackoverflow查看問題,根據上面的問題整理出了一個簡單的加密類,經測試完全符合業務需求,現在寫出來,希望對以后的工作會有幫助。
利用openssl
加密更簡單,而且支持php7.1.x版本,基本可以用於所有版本的php程序。
<?php
class OpenSSLAES
{
/**
* 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);
}
}
$aes = new OpenSSLAES('12345678');
$encrypted = $aes->encrypt('憑欄知瀟雨');
// KSGYvH0GOzQULoLouXqPJA==
echo '要加密的字符串:憑欄知瀟雨<br>加密后的字符串:', $encrypted, '<hr>';
$decrypted = $aes->decrypt($encrypted);
echo '要解密的字符串:', $encrypted, '<br>解密后的字符串:', $decrypted;
經測試,結果和使用mcrypt
加密結果一致。