有没有大神——求可逆的动态加密函数(2-WAY PHP版本)解决办法
程序员文章站
2024-02-11 22:10:28
...
有没有大神——求可逆的动态加密函数(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
------解决方案--------------------
3STUV : ABCD
)IJKL : ABCD
)IJKL : ABCD
Ddefg : ABCD
Zz{
------解决方案--------------------
} : ABCD
@`abc : ABCD
o1234 : ABCD
j,-./ : ABCD
3STUV : ABCD
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 echo $m = encode('ABCD');Iijkl : 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$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$r .= $d[(ord($s{$i}) - 0x21 +($len - $t)) % $len];
}
return $r;
}
3STUV : ABCD
)IJKL : ABCD
)IJKL : ABCD
Ddefg : ABCD
Zz{
------解决方案--------------------
} : ABCD
@`abc : ABCD
o1234 : ABCD
j,-./ : ABCD
3STUV : ABCD
相关文章
相关视频
上一篇: 如何将坐标转换成为IP?