微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php实现aes加密类分享

代码如下:
PHP

class AESMcrypt {public $iv = null;
public $key = null;
public $bit = 128;
private $cipher;public function __construct($bit,$key,$iv,$mode) {
if(empty($bit) || empty($key) || empty($iv) || empty($mode))
return NULL;$this->bit = $bit;
$this->key = $key;
$this->iv = $iv;
$this->mode = $mode;switch($this->bit) {
case 192:$this->cipher = MCRYPT_RIJNDAEL_192; break;
case 256:$this->cipher = MCRYPT_RIJNDAEL_256; break;
default: $this->cipher = MCRYPT_RIJNDAEL_128;
}switch($this->mode) {
case 'ecb':$this->mode = MCRYPT_MODE_ECB; break;
case 'cfb':$this->mode = MCRYPT_MODE_CFB; break;
case 'ofb':$this->mode = MCRYPT_MODE_OFB; break;
case 'nofb':$this->mode = MCRYPT_MODE_NOFB; break;
default: $this->mode = MCRYPT_MODE_CBC;
}
}public function encrypt($data) {
$data = base64_encode(mcrypt_encrypt( $this->cipher,$this->key,$data,$this->mode,$this->iv));
return $data;
}public function decrypt($data) {
$data = mcrypt_decrypt( $this->cipher,base64_decode($data),$this->iv);
$data = rtrim(rtrim($data),"\x00..\x1F");
return $data;
}}

//使用方法
$aes = new AESMcrypt($bit = 128,$key = 'abcdef1234567890',$iv = '0987654321fedcba',$mode = 'cbc');
$c = $aes->encrypt('haowei.me');
var_dump($aes->decrypt($c));

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐