DZX1.5加解密函数authcode分享

函数所在: /source/function/function_core.php

authcode 是使用异或运算进行加密和解密。

原理如下,假如:

加密

明文:1010 1001
密匙:1110 0011
密文:0100 1010

得出密文0100 1010,解密之需和密匙异或下就可以了

解密

密文:0100 1010
密匙:1110 0011
明文:1010 1001

并没有什么高深的算法,密匙重要性很高,所以,关键在于怎么生成密匙。

function authcode($string, $operation = 'DECODE', $key = '', $expiry = ) {

         $ckey_length = 4;

    $key = md5($key != '' ? $key : getglobal('authkey'));

    $keya = md5(substr($key, , 16));

    $keyb = md5(substr($key, 16, 16));

    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, , $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';

 

    $cryptkey = $keya.md5($keya.$keyc);

    $key_length = strlen($cryptkey);

 

    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : ).substr(md5($string.$keyb), , 16).$string;

    $string_length = strlen($string);

 

    $result = '';

    $box = range(, 255);

 

    $rndkey = array();

    for($i = ; $i <= 255; $i++) {

       $rndkey[$i] = ord($cryptkey[$i % $key_length]);

    }

 

    for($j = $i = ; $i < 256; $i++) {

       $j = ($j + $box[$i] + $rndkey[$i]) % 256;

       $tmp = $box[$i];

       $box[$i] = $box[$j];

       $box[$j] = $tmp;

    }

 

    for($a = $j = $i = ; $i < $string_length; $i++) {

       $a = ($a + 1) % 256;

       $j = ($j + $box[$a]) % 256;

       $tmp = $box[$a];

       $box[$a] = $box[$j];

       $box[$j] = $tmp;

       $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));

    }

 

    if($operation == 'DECODE') {

       if((substr($result, , 10) == 0 || substr($result, , 10) - time() > ) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), , 16)) {

           return substr($result, 26);

       } else {

           return '';

       }

    } else {

       return $keyc.str_replace('=', '', base64_encode($result));

    }

 

}


你可能感兴趣的:(DZX1.5加解密函数authcode分享)