Heim > Artikel > Backend-Entwicklung > 有没有大神??求可逆的动态加密函数(2-WAY PHP版本)
http://www.xxx.tld/?user=K5idDC
http://www.xxx.tld/?user=2RK4dm
http://www.xxx.tld/?user=3wemcF
http://www.xxx.tld/?user=492mF3。。。。。。
比如以上user参数的值都指向同一用户名(ABCD)的资料页,有动态可逆的函数这样可以实现一个用户名对应上千个加密字符,如果没有可逆函数,需用数据库保存对应关系的话,那很麻烦!
要求如下:
1、刷新一次可变一次,并且可逆;
2、要和被加密内容差不多长短;
不知道有这样的函数吗?有大神知道吗?麻烦分享一下,谢谢!
网上搜索的DZ函数加密后密文太长了,不合适用作URL
for($i=0; $i<10; $i++) { echo $m = encode('ABCD'); echo ' : ' . decode($m) . PHP_EOL;}function encode($s) { $d = array_map('chr', range(0x21, 0x7e)); $len = count($d); $t = rand(0, $len); $r = $d[$t]; for($i=0; $i<strlen($s); $i++) { $r .= $d[(ord($s{$i}) - 0x21 + $t) % $len]; } return $r;}function decode($s) { $d = array_map('chr', range(0x21, 0x7e)); $len = count($d); $r = ''; $t = array_search($s{0}, $d); for($i=1; $i<strlen($s); $i++) { $r .= $d[(ord($s{$i}) - 0x21 +($len - $t)) % $len]; } return $r;}Iijkl : ABCD
for($i=0; $i<10; $i++) { echo $m = encode('ABCD'); echo ' : ' . decode($m) . PHP_EOL;}function encode($s) { $d = array_map('chr', range(0x21, 0x7e)); $len = count($d); $t = rand(0, $len); $r = $d[$t]; for($i=0; $i<strlen($s); $i++) { $r .= $d[(ord($s{$i}) - 0x21 + $t) % $len]; } return $r;}function decode($s) { $d = array_map('chr', range(0x21, 0x7e)); $len = count($d); $r = ''; $t = array_search($s{0}, $d); for($i=1; $i<strlen($s); $i++) { $r .= $d[(ord($s{$i}) - 0x21 +($len - $t)) % $len]; } return $r;}Iijkl : ABCD
刚刚放到项目去。字符有 / 的就rewrite就出错了
数字的还有很大几率出现 & ,请问有什么办法能让它不出现特殊字符吗?
函数中的数组 $d 是所有允许出现的字符列表,我示例的是全部可打印的ASCII 字符(空格除外)
你可根据你的需求调整其规模
调整一下代码
/*//生成随机字典$d = str_split('0123456789_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ');shuffle($d);echo join('', $d) . PHP_EOL;*/define('DICT', 'hpkE6F0VWb8Cc3Ha_t4OMYl5xPy9ojuRA1dqKBQIJvrLiGsZeNgTm7wzfXDSU2n');for($i=0; $i<10; $i++) { echo $m = encode('ABCD'); echo ' : ' . decode($m) . PHP_EOL;}function encode($s) { $d = str_split(DICT); $len = count($d); $t = rand(0, $len); $r = $d[$t]; for($i=0; $i<strlen($s); $i++) { $r .= $d[(array_search($s{$i}, $d) + $t) % $len]; } return $r;}OTfuH : ABCD
调整一下代码
/*//生成随机字典$d = str_split('0123456789_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ');shuffle($d);echo join('', $d) . PHP_EOL;*/define('DICT', 'hpkE6F0VWb8Cc3Ha_t4OMYl5xPy9ojuRA1dqKBQIJvrLiGsZeNgTm7wzfXDSU2n');for($i=0; $i<10; $i++) { echo $m = encode('ABCD'); echo ' : ' . decode($m) . PHP_EOL;}function encode($s) { $d = str_split(DICT); $len = count($d); $t = rand(0, $len); $r = $d[$t]; for($i=0; $i<strlen($s); $i++) { $r .= $d[(array_search($s{$i}, $d) + $t) % $len]; } return $r;}OTfuH : ABCD
噢,贴漏了
function decode($s) { $d = str_split(DICT); $len = count($d); $r = ''; $t = array_search($s{0}, $d); for($i=1; $i<strlen($s); $i++) { $r .= $d[(array_search($s{$i}, $d) + ($len - $t)) % $len]; } return $r;}
噢,贴漏了
function decode($s) { $d = str_split(DICT); $len = count($d); $r = ''; $t = array_search($s{0}, $d); for($i=1; $i<strlen($s); $i++) { $r .= $d[(array_search($s{$i}, $d) + ($len - $t)) % $len]; } return $r;}
这个得跟踪一下
明文4个字符,密文应5个字符,对于明文 ABCD 密文 ABCD 明显是少了一个字符
function get_encode($s){ $en_s = encode($s); if($en_s == $s) { return get_encode($s); }else { return $en_s; }}
噢,贴漏了
function decode($s) { $d = str_split(DICT); $len = count($d); $r = ''; $t = array_search($s{0}, $d); for($i=1; $i<strlen($s); $i++) { $r .= $d[(array_search($s{$i}, $d) + ($len - $t)) % $len]; } return $r;}
噢,贴漏了
function decode($s) { $d = str_split(DICT); $len = count($d); $r = ''; $t = array_search($s{0}, $d); for($i=1; $i<strlen($s); $i++) { $r .= $d[(array_search($s{$i}, $d) + ($len - $t)) % $len]; } return $r;}