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
3STUV : ABCD
)IJKL : ABCD
)IJKL : ABCD
Ddefg : ABCD
Zz{|} : ABCD
@`abc : ABCD
o1234 : ABCD
j,-./ : ABCD
3STUV : ABCD
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
3STUV : ABCD
)IJKL : ABCD
)IJKL : ABCD
Ddefg : ABCD
Zz{|} : ABCD
@`abc : ABCD
o1234 : ABCD
j,-./ : ABCD
3STUV : ABCD
大神还是这里的强!谢谢!有没有办法去掉特殊符号呢?用来做URL不太好吧?
你可根据你的需求调整其规模
//生成随机字典
$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
oUkI5 : ABCD
ciN5V : ABCD
6Kvan : ABCD
4gzj3 : ABCD
un6vP : ABCD
So1Vw : ABCD
mYyhZ : ABCD
Z_YDr : ABCD
FBr_h : ABCD
$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;
}
9SpQl : ABCD
yDhBY : ABCD
LctwQ : ABCD
dEWGj : ABCD
xf2qO : ABCD
ABCD : Fry
VIi4k : ABCD
etlSL : ABCD
un6vP : ABCD
PXnKM : ABCD太感谢!接近完美了,美中不足的是偶尔会出现 “ ABCD : Fry ” 这样的情况。
现在用笨方法过滤,先for 10 次,逐条比较取一条正确的出来。
明文4个字符,密文应5个字符,对于明文 ABCD 密文 ABCD 明显是少了一个字符
function get_encode($s)
{
$en_s = encode($s);
if($en_s == $s) {
return get_encode($s);
}else {
return $en_s;
}
}用了递归效率比较好一些了,加密解密算法知识几乎为0,等项目完成后狠狠恶补一下,请问斑竹大神有没有这方面的书推荐一下!
9SpQl : ABCD
yDhBY : ABCD
LctwQ : ABCD
dEWGj : ABCD
xf2qO : ABCD
ABCD : Fry
VIi4k : ABCD
etlSL : ABCD
un6vP : ABCD
PXnKM : ABCD太感谢!接近完美了,美中不足的是偶尔会出现 “ ABCD : Fry ” 这样的情况。
现在用笨方法过滤,先for 10 次,逐条比较取一条正确的出来。是加密的时候$t = rand(0, $len);这里错了,应该是$t = rand(0, $len-1);
9SpQl : ABCD
yDhBY : ABCD
LctwQ : ABCD
dEWGj : ABCD
xf2qO : ABCD
ABCD : Fry
VIi4k : ABCD
etlSL : ABCD
un6vP : ABCD
PXnKM : ABCD太感谢!接近完美了,美中不足的是偶尔会出现 “ ABCD : Fry ” 这样的情况。
现在用笨方法过滤,先for 10 次,逐条比较取一条正确的出来。是加密的时候$t = rand(0, $len);这里错了,应该是$t = rand(0, $len-1);
在PHPCHINA那问了几天没人回,在这几小时就解决了!!真的谢谢!