Heim >Backend-Entwicklung >PHP-Tutorial >Von PHP implementierte AES-Verschlüsselungsklasse
Advanced Encryption Standard (englisch: Advanced Encryption Standard, Abkürzung: AES), in der Kryptographie auch als Rijndael-Verschlüsselungsmethode bekannt, ist ein Blockverschlüsselungsstandard, der von der US-Bundesregierung übernommen wurde. Dieser Standard ersetzt den ursprünglichen DES. Er wurde von vielen Parteien analysiert und ist weltweit weit verbreitet. Nach einem fünfjährigen Auswahlverfahren wurde der Advanced Encryption Standard am 26. November 2001 vom National Institute of Standards and Technology (NIST) in FIPS PUB 197 veröffentlicht und wurde am 26. Mai 2002 zu einem wirksamen Standard. Im Jahr 2006 hat sich Advanced Encryption Standard zu einem der beliebtesten Algorithmen für die Verschlüsselung mit symmetrischen Schlüsseln entwickelt. In diesem Artikel wird hauptsächlich die in PHP implementierte AES-Verschlüsselungsklasse vorgestellt. Freunde, die sie benötigen, können darauf verweisen
<?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));
Das obige ist der detaillierte Inhalt vonVon PHP implementierte AES-Verschlüsselungsklasse. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!