Von PHP implementierte AES-Verschlüsselungsklasse

怪我咯
Freigeben: 2023-03-13 19:48:01
Original
2692 Leute haben es durchsucht

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 &#39;ecb&#39;:$this->mode = MCRYPT_MODE_ECB; break;
   case &#39;cfb&#39;:$this->mode = MCRYPT_MODE_CFB; break;
   case &#39;ofb&#39;:$this->mode = MCRYPT_MODE_OFB; break;
   case &#39;nofb&#39;:$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 = &#39;abcdef1234567890&#39;, $iv = &#39;0987654321fedcba&#39;, $mode = &#39;cbc&#39;);
$c = $aes->encrypt(&#39;haowei.me&#39;);
var_dump($aes->decrypt($c));
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage