php源码分析之DZX1.5加密解密函数authcode用法
本文实例讲述了php源码分析之DZX1.5加密解密函数authcode用法。分享给大家供大家参考。具体分析如下:
<?php $authkey=''; /** *@paramstring$string:输入的需要加密(或解密)的明文(或密文) *@paramstring$operation:'DECODE'或其它,其中默认表示解密,输入其它表示加密 *@paramstring$key:加解密密钥 *@paramint$expiry:有效期 */ functionauthcode($string,$operation='DECODE',$key='',$expiry=0){ global$authkey; $ckey_length=4; $key=md5($key!=''?$key:$authkey); $keya=md5(substr($key,0,16)); $keyb=md5(substr($key,16,16)); $keyc=$ckey_length?($operation=='DECODE'?substr($string,0,$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():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++){ $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++){ $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,0,10)==0||substr($result,0,10)-time()>0)&&substr($result,10,16)==substr(md5(substr($result,26).$keyb),0,16)){ returnsubstr($result,26); }else{ return''; } }else{ return$keyc.str_replace('=','',base64_encode($result)); } } $str='1234'; $key='1234'; echo"明文:".$str; echo"<br/>"; echo"密钥:".$key; $encode=authcode($str,'11',$key); echo"<br/>"; echo"加密后的密文:".$encode; echo"<br/>"; $decode=authcode($encode,'DECODE',$key); echo"解密后的明文:".$decode; /*Endofphp*/
运行结果如下:
明文:1234
密钥:1234
加密后的密文:a52f67eXZGVy0HtQBo4vOREhq3WxnL6E2zlx75JGfoJW
解密后的明文:1234
希望本文所述对大家的php程序设计有所帮助。