1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- <?php
- namespace toolkits;
- class Aec
- {
- /**
- * 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向量 初始化向量 16位字符串
- * @param mixed $options 0为默认模式,自动对明文进行 pkcs7 padding,且数据做 base64 编码处理
- *
- */
- public function __construct($key, $iv = null, $method = 'AES-128-CBC', $options = 0)
- {
- // key是必须要设置的
- $this->secret_key = isset($key) ? $key : 'yunxiekeji';
- $this->method = $method;
- $this->iv = $iv;
- $this->options = $options;
- }
- /**
- * 加密方法,对数据进行加密,返回加密后的数据
- *
- * @param string $data 要加密的数据
- *
- * @return string
- *
- */
- public function encrypt($data)
- {
- return base64_encode(openssl_encrypt($data, $this->method, $this->secret_key, $this->options, $this->iv));
- }
- /**
- * 解密方法,对数据进行解密,返回解密后的数据
- *
- * @param string $data 要解密的数据
- *
- * @return string
- *
- */
- public function decrypt($data)
- {
- return openssl_decrypt(base64_decode($data), $this->method, $this->secret_key, $this->options, $this->iv);
- }
- }
|