在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
function passport_encrypt($txt, $key) {
srand((double)microtime() * 1000000); $encrypt_key = md5(rand(0, 32000)); $ctr = 0; $tmp = ''; for($i = 0;$i < strlen($txt); $i++) { $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; $tmp .= $encrypt_key[$ctr].($txt[$i] ^ $encrypt_key[$ctr++]); } return base64_encode(passport_key($tmp, $key)); } function passport_decrypt($txt, $key) { $txt = passport_key(base64_decode($txt), $key); $tmp = ''; for($i = 0;$i < strlen($txt); $i++) { $md5 = $txt[$i]; $tmp .= $txt[++$i] ^ $md5; } return $tmp; } function passport_key($txt, $encrypt_key) { $encrypt_key = md5($encrypt_key); $ctr = 0; $tmp = ''; for($i = 0; $i < strlen($txt); $i++) { $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; $tmp .= $txt[$i] ^ $encrypt_key[$ctr++]; } return $tmp; } perl的,转自 http://sakuras.cn/2007/01/perlazdg.html
###########加密解密模块开始###############################
use Digest::MD5 qw(md5_hex); use MIME::Base64; #加密模块 sub passport_encrypt { my($txt, $key,$ctr,$tmp)=(shift,shift,0,undef); srand; my $encrypt_key = md5_hex(rand 32000); for(my $i = 0; $i < length($txt); $i++) { #如果 $ctr = $encrypt_key 的长度,则 $ctr 清零 $ctr = $ctr == length($encrypt_key) ? 0 : $ctr; #$tmp 字串在末尾增加两位,其第一位内容为 $encrypt_key 的第 $ctr 位, 第二位内容为 $txt 的第 $i 位与 $encrypt_key 的 $ctr 位取异或。然后 $ctr = $ctr + 1 $tmp .= substr($encrypt_key,$ctr,1).(substr($txt,$i,1) ^ substr($encrypt_key,$ctr,1)); $ctr++; } #返回结果,结果为 passport_key() 函数返回值的 base64 编码结果 return encode_base64(passport_key($tmp, $key)); } #解密模块 sub passport_decrypt{ my ($txt, $key,$tmp)=(shift,shift,undef); #$txt 的结果为加密后的字串经过 base64 解码,然后与私有密匙一起经过 passport_key() 函数处理后的返回值 $txt = passport_key(decode_base64($txt), $key); #for 循环,$i 为从 0 开始,到小于 $txt 字串长度的整数 for (my $i = 0; $i < length($txt); $i++) { # $tmp 字串在末尾增加一位,其内容为 $txt 的第 $i 位与 $txt 的第 $i + 1 位取异或。然后 $i = $i + 1 $tmp .= substr($txt,$i,1) ^substr($txt,++$i,1); } #返回 $tmp 的值作为结果 return $tmp; } #密匙模块 sub passport_key { my ($txt, $encrypt_key,$ctr,$tmp)=(shift,shift,0,undef); #将 $encrypt_key 赋为 $encrypt_key 经 md5() 后的值 $encrypt_key = md5_hex($encrypt_key); #for 循环,$i 为从 0 开始,到小于 $txt 字串长度的整数 for(my $i = 0; $i < length($txt); $i++) { #如果 $ctr = $encrypt_key 的长度,则 $ctr 清零 $ctr = $ctr == length($encrypt_key) ? 0 : $ctr; #$tmp 字串在末尾增加一位,其内容为 $txt 的第 $i 位, 与 $encrypt_key 的第 $ctr + 1 位取异或。然后 $ctr = $ctr + 1 $tmp .= substr($txt,$i,1) ^ substr($encrypt_key,$ctr,1); $ctr++; } # 返回 $tmp 的值作为结果 return $tmp; } ###########加密解密模块结束############################### |
请发表评论