Home > Backend Development > PHP Tutorial > 有没有大神——求可逆的动态加密函数(2-WAY PHP版本)解决办法

有没有大神——求可逆的动态加密函数(2-WAY PHP版本)解决办法

WBOY
Release: 2016-06-13 12:05:20
Original
891 people have browsed it

有没有大神——求可逆的动态加密函数(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++) {<br />  echo $m = encode('ABCD');<br />  echo ' : ' . decode($m) . PHP_EOL;<br />}<br /><br />function encode($s) {<br />  $d = array_map('chr', range(0x21, 0x7e));<br />  $len = count($d);<br />  $t = rand(0, $len);<br />  $r = $d[$t];<br />  for($i=0; $i<strlen($s); $i++) {<br />    $r .= $d[(ord($s{$i}) - 0x21 + $t) % $len];<br />  }<br />  return $r;<br />}<br /><br />function decode($s) {<br />  $d = array_map('chr', range(0x21, 0x7e));<br />  $len = count($d);<br />  $r = '';<br />  $t = array_search($s{0}, $d);<br />  for($i=1; $i<strlen($s); $i++) {<br />    $r .= $d[(ord($s{$i}) - 0x21 +($len - $t)) % $len];<br />  }<br />  return $r;<br />}<br />
Copy after login
Iijkl : ABCD
3STUV : ABCD
)IJKL : ABCD
)IJKL : ABCD
Ddefg : ABCD
Zz{
------解决方案--------------------
} : ABCD
@`abc : ABCD
o1234 : ABCD
j,-./ : ABCD
3STUV : ABCD

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template