对于需要还原的信息,则需要采用可逆的加密解密算法。下面小编为大家整理了PHP可逆加密解密算法,希望能帮到大家!

  下面一组PHP函数是实现此加密解密的方法:

  加密算法如下:

  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, $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;}

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

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

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

  gniCSOzZG+HnS9zcFea7SefNGhXF

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

1.《php解密 PHP可逆加密解密算法》援引自互联网,旨在传递更多网络信息知识,仅代表作者本人观点,与本网站无关,侵删请联系页脚下方联系方式。

2.《php解密 PHP可逆加密解密算法》仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证。

3.文章转载时请保留本站内容来源地址,https://www.lu-xu.com/jiaoyu/97380.html