很多時候我們需要對資料進行加密解密,比如有些資料需要儲存到cookie中,但又不能被使用者輕易得到這些資料,這時我們就需要加密這些資料儲存到cookie中,等我們需要使用它們的時候再解密。
加密的過程如下:01 // 加密資料並寫到cookie裡
02 $cookie_data = $this -> encrypt("nowamagic", $data);
03
04 $cookie = array(
05 'name' => '$data',
06 'value' => $cookie_data,
07 'expire' => $user_expire,
08 'domain' => '',
09 'path' => '/',
10 'prefix' => ''
11 );
12 $this->input->set_cookie($cookie);
13
14 // 加密
15 public function encrypt($key, $plain_text) {
16 $plain_text = trim($plain_text);
17 $iv = substr(md5($key), 0,mcrypt_get_iv_size (MCRYPT_CAST_256,MCRYPT_MODE_CFB));
18 $c_t = mcrypt_cfb (MCRYPT_CAST_256, $key, $plain_text, MCRYPT_ENCRYPT, $iv);
19 return trim(chop(base64_encode($c_t)));
20 }
使用的時候再解密:01 if( isset($_COOKIE['data']) )
02 {
03 //用cookie給session賦值
04 $_SESSION['data'] = decrypt("nowamagic", $_COOKIE['data']);
05 }
06
07 function decrypt($key, $c_t) {
08 $c_t = trim(chop(base64_decode($c_t)));
09 $iv = substr(md5($key), 0,mcrypt_get_iv_size (MCRYPT_CAST_256,MCRYPT_MODE_CFB));
10 $p_t = mcrypt_cfb (MCRYPT_CAST_256, $key, $c_t, MCRYPT_DECRYPT, $iv);
11 return trim(chop($p_t));
12 }
這裡記錄下這個可逆的加密函數的使用。