您好,欢迎访问一九零五行业门户网

php实现的aes加密类

高级加密标准(英语:advanced encryption standard,缩写:aes),在密码学中又称rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的des,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(nist)于2001年11月26日发布于fips pub 197,并在2002年5月26日成为有效的标准。2006年,高级加密标准已然成为对称密钥加密中最流行的算法之一。这篇文章主要介绍了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, $this->key, base64_decode($data), $this->mode, $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));
以上就是php实现的aes加密类的详细内容。
其它类似信息

推荐信息