ホームページ  >  記事  >  php教程  >  シンプルな AES 暗号化および復号化アルゴリズムの使用法と PHP (256 ビット) での例

シンプルな AES 暗号化および復号化アルゴリズムの使用法と PHP (256 ビット) での例

WBOY
WBOYオリジナル
2016-06-21 08:50:58862ブラウズ

 

クラス aes {

 

    // CRYPTO_CIPHER_BLOCK_SIZE 32

 

private $_secret_key = 'default_secret_key';

 

パブリック関数 setKey($key) {

$this->_secret_key = $key;

}

 

パブリック関数 encode($data) {

$td = mcrypt_module_open(MCRYPT_RIJNDAEL_256,'',MCRYPT_MODE_CBC,'');

$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND);

mcrypt_generic_init($td,$this->_secret_key,$iv);

$encrypted = mcrypt_generic($td,$data);

mcrypt_generic_deinit($td);

 

$iv を返します。 $encrypted;

}

 

パブリック関数 decode($data) {

$td = mcrypt_module_open(MCRYPT_RIJNDAEL_256,'',MCRYPT_MODE_CBC,'');

$iv = mb_substr($data,0,32,'latin1');

mcrypt_generic_init($td,$this->_secret_key,$iv);

$data = mb_substr($data,32,mb_strlen($data,'latin1'),'latin1');

$data = mdecrypt_generic($td,$data);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

 

戻りトリム($data);

}

}

 

$aes = new aes();

$aes->setKey('key');

 

// 加密

$aes->encode('string');

// 解密

$aes->decode($string);

?>



声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。