PHP加密函数与解密函数详解

来自:网络
时间:2023-01-03
阅读:

去网上找了下。

Php常用的加密函数有

MD5加密(不可逆)、Crypt加密(不可逆)、Sha1加密(不可逆)、Urlencode加密(可逆)

base64编码加密(可逆)

还是见识的太少,这其中我只用过MD5和base64

最常用的还是MD5 ,MD5的加密虽不可逆,但一些简单的 两次MD5加密的字符串,花点钱还是能解密的。

为了防止解密一般都是对字符串进行MD5加密,在加密过得字符串上加一个固定字符串,再进行MD5加密。(感觉好麻烦……)

分享一个自用的加密和解密函数

/** 
* 加密 
* @param string $string     要加密或解密的字符串 
* @param string $operation 加密 ''  解密 DECODE 
* @param string $key        密钥,加密解密时保持一致 
* @param int    $expiry 有效时长,单位:秒 
* @return string 
*/  
function encrypt_code($string, $expiry = 0, $key = '1234567890') {  
    $ckey_length = 1;  
    $key = md5($key ? $key : UC_KEY); //加密解密时这个是不变的  
    $keya = md5(substr($key, 0, 16)); //加密解密时这个是不变的  
    $keyb = md5(substr($key, 16, 16)); //加密解密时这个是不变的  
    $keyc = $ckey_length ?  substr(md5(microtime()), -$ckey_length) : '';  
    $cryptkey = $keya . md5($keya . $keyc); //64  
    $key_length = strlen($cryptkey); //64  
   
    $string =sprintf('%010d', $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb), 0, 16) . $string;  
    $string_length = strlen($string);  
   
    $result = '';  
    $box = range(0, 255);  
   
    $rndkey = array();  
    for ($i = 0; $i <= 255; $i++) { //字母表 64位后重复 数列 范围为48~122  
        $rndkey[$i] = ord($cryptkey[$i % $key_length]);  
    }  
   
    for ($j = $i = 0; $i < 256; $i++) { //这里是一个打乱算法  
        $j = ($j + $box[$i] + $rndkey[$i]) % 256;  
        $tmp = $box[$i];  
        $box[$i] = $box[$j];  
        $box[$j] = $tmp;  
    }  
    for ($a = $j = $i = 0; $i < $string_length; $i++) {  
        $result .= chr(ord($string[$i]) ^ ($box[$i]));  
       
    }  
     $str =  $keyc . str_replace('=', '', base64_encode($result));    
                //  $str =htmlentities($str, ENT_QUOTES, "UTF-8"); // curl 访问出错  
                  return $str ;  
}  
  
               
/** 
* 解密 
* @param string $string     要加密或解密的字符串 
* @param string $operation 加密 ''  解密 DECODE 
* @param string $key        密钥,加密解密时保持一致 
* @param int    $expiry 有效时长,单位:秒 
* @return string 
*/  
function encrypt_decode($string, $expiry = 0,$key = '1234567890') {    
    $ckey_length = 1;  
    $key = md5($key ? $key : UC_KEY); //加密解密时这个是不变的  
    $keya = md5(substr($key, 0, 16)); //加密解密时这个是不变的  
    $keyb = md5(substr($key, 16, 16)); //加密解密时这个是不变的  
                
    $keyc = $ckey_length ?  substr($string, 0, $ckey_length)   : '';  
  
    $cryptkey = $keya . md5($keya . $keyc); //64  
    $key_length = strlen($cryptkey); //64  
    $string = base64_decode(substr($string, $ckey_length)) ;  
               $string_length = strlen($string);  
    $result = '';  
    $box = range(0, 255);  
  
    $rndkey = array();  
    for ($i = 0; $i <= 255; $i++) { //字母表 64位后重复 数列 范围为48~122  
        $rndkey[$i] = ord($cryptkey[$i % $key_length]);  
    }  
    for ($j = $i = 0; $i < 256; $i++) { //这里是一个打乱算法  
        $j = ($j + $box[$i] + $rndkey[$i]) % 256;  
  
        $tmp = $box[$i];  
        $box[$i] = $box[$j];  
        $box[$j] = $tmp;  
    }  
    for($a = $j = $i = 0; $i < $string_length; $i++) {  
        $result .= chr(ord($string[$i]) ^ ($box[$i]));  
    }  
    if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb), 0, 16)) {  
       return substr($result, 26);  
    }else{  
       return false;  
    }  
}

注:加密函数与解密函数中的 $key 必须完全相同。

返回顶部
顶部