php url地址中参数加密问题
在我们常用的加密方法中,有的是可逆有些是不可逆的,比如我们经常使用的base64_encode() 和 base64_decode() 为可逆的加密方式,不可逆的我们常用的MD5 等,但是一般url加密当我们涉及到参数的时候都会选择可逆的加密方法,我们今天介绍的方法是在base64_encode上面去改良的,因为base64_encode有些特殊字符被加密以后,参数接收的时候会因为一些特殊字符导致接收参数不对,直接上代码了!
原理很简单就是我们把一些可能存在的特殊字符先处理再加密!
/**
* @ 路径加密
**/
function enPssUrl($data, $key="urlPass")
{
$key = md5($key);
$x = 0;
$len = strlen($data);
$l = strlen($key);
$char = "";
$str = "";
for ($i = 0; $i < $len; $i++)
{
if ($x == $l)
{
$x = 0;
}
$char .= $key{$x};
$x++;
}
for ($i = 0; $i < $len; $i++)
{
$str .= chr(ord($data{$i}) + (ord($char{$i})) % 256);
}
return base64_encode($str);
}
/**
* @ 路径解密
**/
function dePssUrl($data, $key="urlPass")
{
$key = md5($key);
$x = 0;
$data = base64_decode($data);
$len = strlen($data);
$l = strlen($key);
$char = "";
for ($i = 0; $i < $len; $i++)
{
if ($x == $l)
{
$x = 0;
}
$char .= substr($key, $x, 1);
$x++;
}
$str = "";
for ($i = 0; $i < $len; $i++)
{
if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1)))
{
$str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));
}
else
{
$str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));
}
}
return $str;
}