加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php加密算法之实现可逆加密算法和解密分享

发布时间:2020-12-12 20:01:51 所属栏目:PHP教程 来源:网络整理
导读:加密算法如下: 代码如下: function encrypt($data,$key) { $key=md5($key); $x=0; $len=strlen($data); $l=strlen($key); for ($i = 0; $i { if ($x == $l) { $x = 0; } $char .= $key{$x}; $x++; } for ($i = 0; $i { $str .= chr(ord($data{$i}) + (ord($

加密算法如下:

代码如下:
function encrypt($data,$key)
{
$key=md5($key);
$x=0;
$len=strlen($data);
$l=strlen($key);
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 decrypt($data,$key)
{
$key = md5($key);
$x = 0;
$data = base64_decode($data);
$len = strlen($data);
$l = strlen($key);
for ($i = 0; $i < $len; $i++)
{
if ($x == $l)
{
$x = 0;
}
$char .= substr($key,$x,1);
$x++;
}
for ($i = 0; $i < $len; $i++)
{
if (ord(substr($data,$i,1)) < ord(substr($char,1)))
{
$str .= chr((ord(substr($data,1)) + 256) - ord(substr($char,1)));
}
else
{
$str .= chr(ord(substr($data,1)) - ord(substr($char,1)));
}
}
return $str;
}

上述加密解密的过程均需要用到一个加密密钥(即参数$key)。

代码如下:
$data = 'PHP加密解密算法';// 被加密信息
$key = '123';// 密钥
$encrypt = encrypt($data,$key);
$decrypt = decrypt($encrypt,$key);
echo $encrypt,"n",$decrypt;

上述将输出类似如下结果:

代码如下:
gniCSOzZG+HnS9zcFea7SefNGhXF
PHP加密解密算法

从上述结果可以看出,这是一组可逆的加密解密算法,可以用于部分需要还原的数据加密。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读