ホームページ  >  記事  >  バックエンド開発  >  php の 3des 暗号化コード (.net と完全互換)_PHP チュートリアル

php の 3des 暗号化コード (.net と完全互換)_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-21 15:17:02876ブラウズ

复制代码代码如下:

class Crypt3Des
{
private $key = "";
プライベート $iv = "";
/**
* 構築し、2 つの Base64_encoded KEY と IV を渡します
*
* @param string $key
* @param string $iv
*/
function __construct ($key, $iv)
{
if (empty($key) || empty($iv)) {
echo 'key と iv が無効です';
終了();
}
$this->key = $key;
$this->iv = $iv;
}
/**
*加密
* @param $value
* @return
*/
public function encrypt ($value)
{
$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
$iv = Base64_decode($this->iv);
$value = $this->PaddingPKCS7($value);
$key = Base64_decode($this->key);
mcrypt_generic_init($td, $key, $iv);
$ret =base64_encode(mcrypt_generic($td, $value));
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
$ret を返す;
}
/**
*解密
* @param $value
* @return
*/
public function decrypt ($value)
{
$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
$iv = Base64_decode($this->iv);
$key = Base64_decode($this->key);
mcrypt_generic_init($td, $key, $iv);
$ret = トリム(mdecrypt_generic($td,base64_decode($value)));
$ret = $this->UnPaddingPKCS7($ret);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
$ret を返す;
}
プライベート関数 PaddingPKCS7 ($data)
{
$block_size = mcrypt_get_block_size('tripledes', 'cbc');
$padding_char = $block_size - (strlen($data) % $block_size);
$data .= str_repeat(chr($padding_char), $padding_char);
$data を返す;
}
プライベート関数 UnPaddingPKCS7 ($text)
{
$pad = ord($text{strlen($text) - 1});
if ($pad > strlen($text)) {
return false;
}
if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) {
return false;
}
return substr($text, 0, - 1 * $pad);
}
}
?>

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/325779.html技術記事复制代码代码如下: ?php class Crypt3Des { private $key = "";プライベート $iv = ""; /** * 构造,传递二个已经実行base64_encodeのKEY与IV * * @param string $key * @par...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。