首頁 > 後端開發 > php教程 > 一個簡潔的PHP可逆加密函數

一個簡潔的PHP可逆加密函數

WBOY
發布: 2016-07-25 08:43:19
原創
990 人瀏覽過

很多时候我们需要对数据进行加密解密,比如有些数据需要保存到cookie中,但又不能被用户轻易得到这些数据,这时我们就需要加密这些数据保存到cookie中,等我们需要使用它们的时候再解密。

  1. // 加密数据并写到cookie里
  2. $cookie_data = $this -> encrypt("nowamagic", $data);
  3. $cookie = array(
  4. 'name' => '$data',
  5. 'value' => $cookie_data,
  6. 'expire' => $user_expire,
  7. 'domain' => '',
  8. 'path' => '/',
  9. 'prefix' => ''
  10. );
  11. $this->input->set_cookie($cookie);
  12. // 加密
  13. public function encrypt($key, $plain_text) {
  14. $plain_text = trim($plain_text);
  15. $iv = substr(md5($key), 0,mcrypt_get_iv_size (MCRYPT_CAST_256,MCRYPT_MODE_CFB));
  16. $c_t = mcrypt_cfb (MCRYPT_CAST_256, $key, $plain_text, MCRYPT_ENCRYPT, $iv);
  17. return trim(chop(base64_encode($c_t)));
  18. }
  19. 使用的时候再解密:
  20. if( isset($_COOKIE['data']) )
  21. {
  22. //用cookie给session赋值
  23. $_SESSION['data'] = decrypt("nowamagic", $_COOKIE['data']);
  24. }
  25. function decrypt($key, $c_t) {
  26. $c_t = trim(chop(base64_decode($c_t)));
  27. $iv = substr(md5($key), 0,mcrypt_get_iv_size (MCRYPT_CAST_256,MCRYPT_MODE_CFB));
  28. $p_t = mcrypt_cfb (MCRYPT_CAST_256, $key, $c_t, MCRYPT_DECRYPT, $iv);
  29. return trim(chop($p_t));
  30. }
复制代码

这里记录下这个可逆的加密函数的使用。

PHP


來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板