ホームページ >バックエンド開発 >PHPチュートリアル >PHP で Cookie 暗号化を実装する方法、phpcookie 暗号化_PHP チュートリアル
この記事の例では、PHP で Cookie 暗号化を実装する方法について説明します。皆さんの参考に共有してください。具体的な実装方法は以下の通りです
コードをコピーします コードは次のとおりです:
クッキークラス
{
/**
* 暗号化された Cookie を復号化します
*
* @param string $encryptedText
* @戻り文字列
*/
プライベート静的関数 _decrypt($encryptedText)
{
$key = Config::get('secret_key');
$cryptText =base64_decode($encryptedText);
$ivSize = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($ivSize, MCRYPT_RAND);
$decryptText = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, $cryptText, MCRYPT_MODE_ECB, $iv);
returnrim($decryptText);
}
/**
* 暗号化されたクッキー
*
* @param string $plainText
* @戻り文字列
*/
プライベート静的関数 _encrypt($plainText)
{
$key = Config::get('secret_key');
$ivSize = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($ivSize, MCRYPT_RAND);
$encryptText = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $plainText, MCRYPT_MODE_ECB, $iv);
return trim(base64_encode($encryptText));
}
/**
* Cookie を削除します
*
* @param 配列 $args
* @return boolean
*/
パブリック静的関数 del($args)
{
$name = $args['name'];
$domain = isset($args['domain']) $args['domain'] : null;
return isset($_COOKIE[$name]) ? setcookie($name, '', time() - 86400, '/', $domain) : true;
}
/**
* 指定したCookieの値を取得します
*
* @param string $name
*/
パブリック静的関数 get($name)
{
戻り isset($_COOKIE[$name]) ? self::_decrypt($_COOKIE[$name]) : null;
}
/**
* クッキーを設定します
*
* @param 配列 $args
* @return boolean
*/
パブリック静的関数セット($args)
{
$name = $args['name'];
$value= self::_encrypt($args['value']);
$expire = isset($args['expire']) $args['expire'] : null;
$path = isset($args['path']) $args['path'] : '/';
$domain = isset($args['domain']) $args['domain'] : null;
$secure = isset($args['secure']) $args['secure'] : 0;
return setcookie($name, $value, $expire, $path, $domain, $secure);
}
}
この記事で説明した内容が皆様の PHP プログラミング設計に役立つことを願っています。