zoukankan      html  css  js  c++  java
  • 一个简洁的PHP可逆加密函数(分享)

    http://www.jb51.net/article/38018.htm

    本篇文章是对一个简洁的PHP可逆加密函数进行了详细的分析介绍,需要的朋友参考下
     

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

    加密的过程如下:

    复制代码代码如下:

    // 加密数据并写到cookie里
    $cookie_data = $this -> encrypt("nowamagic", $data);

    $cookie = array(
        'name'   => '$data',
        'value'  => $cookie_data,
        'expire' => $user_expire,
        'domain' => '',
        'path'   => '/',
        'prefix' => ''
    );
    $this->input->set_cookie($cookie);

    // 加密
    public function encrypt($key, $plain_text) {  
        $plain_text = trim($plain_text);  
        $iv = substr(md5($key), 0,mcrypt_get_iv_size (MCRYPT_CAST_256,MCRYPT_MODE_CFB));  
        $c_t = mcrypt_cfb (MCRYPT_CAST_256, $key, $plain_text, MCRYPT_ENCRYPT, $iv);  
        return trim(chop(base64_encode($c_t)));  

    使用的时候再解密:
    if( isset($_COOKIE['data']) )
    {
        //用cookie给session赋值
        $_SESSION['data'] = decrypt("nowamagic", $_COOKIE['data']);
    }

    function decrypt($key, $c_t) {  
        $c_t = trim(chop(base64_decode($c_t)));  
        $iv = substr(md5($key), 0,mcrypt_get_iv_size (MCRYPT_CAST_256,MCRYPT_MODE_CFB));  
        $p_t = mcrypt_cfb (MCRYPT_CAST_256, $key, $c_t, MCRYPT_DECRYPT, $iv);  
        return trim(chop($p_t));  
    }  


    这里记录下这个可逆的加密函数的使用。
  • 相关阅读:
    前nginx后Apache+Node反向代理
    JavaScript面试时候的坑洼沟洄——逗号、冒号与括号
    JavaScript面试时候的坑洼沟洄——表达式与运算符
    JavaScript面试时候的坑洼沟洄——数据类型
    容易被忽略CSS特性
    常用CSS优化总结——网络性能与语法性能建议
    quic-go测试
    golang证书认证通信
    golang爬虫
    websocket概述
  • 原文地址:https://www.cnblogs.com/lxwphp/p/7866410.html
Copyright © 2011-2022 走看看