一组PHP可逆加密解密算法
来源:互联网 发布:谷嫂淘宝同款 破解版 编辑:程序博客网 时间:2024/05/19 12:24
对于大部分密码加密,我们可以采用md5、sha1等方法。可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密。
对于需要还原的信息,则需要采用可逆的加密解密算法。
下面一组PHP函数是实现此加密解密的方法:
对于需要还原的信息,则需要采用可逆的加密解密算法。
下面一组PHP函数是实现此加密解密的方法:
加密算法如下:
1 function encrypt($data, $key) 2 { 3 $key = md5($key); 4 $x = 0; 5 $len = strlen($data); 6 $l = strlen($key); 7 for ($i = 0; $i < $len; $i++) 8 { 9 if ($x == $l) 10 {11 $x = 0;12 }13 $char .= $key{$x};14 $x++;15 }16 for ($i = 0; $i < $len; $i++)17 {18 $str .= chr(ord($data{$i}) + (ord($char{$i})) % 256);19 }20 return base64_encode($str);21 }
解密算法如下:
1 function decrypt($data, $key) 2 { 3 $key = md5($key); 4 $x = 0; 5 $data = base64_decode($data); 6 $len = strlen($data); 7 $l = strlen($key); 8 for ($i = 0; $i < $len; $i++) 9 {10 if ($x == $l) 11 {12 $x = 0;13 }14 $char .= substr($key, $x, 1);15 $x++;16 }17 for ($i = 0; $i < $len; $i++)18 {19 if (ord(substr($data, $i, 1)) < ord(substr($char, $i, 1)))20 {21 $str .= chr((ord(substr($data, $i, 1)) + 256) - ord(substr($char, $i, 1)));22 }23 else24 {25 $str .= chr(ord(substr($data, $i, 1)) - ord(substr($char, $i, 1)));26 }27 }28 return $str;29 }
上述加密解密的过程均需要用到一个加密密钥(即参数$key)。
1 $data = 'PHP加密解密算法'; // 被加密信息2 $key = '123'; // 密钥3 $encrypt = encrypt($data, $key);4 $decrypt = decrypt($encrypt, $key);5 echo $encrypt, "\n", $decrypt;
上述将输出类似如下结果:
gniCSOzZG+HnS9zcFea7SefNGhXF
PHP加密解密算法
从上述结果可以看出,这是一组可逆的加密解密算法,可以用于部分需要还原的数据加密。
阅读全文
0 0
- 一组PHP可逆加密解密算法
- PHP一组可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- 一组PHP可逆加密解密算法
- PHP可逆加密解密算法
- PHP可逆加密解密算法
- PHP可逆加密解密算法
- php可逆的加密解密算法实现
- PHP-可逆加密解密算法总结
- 简易可逆加密解密算法
- PHP 动态可逆加密解密函数
- 学习php需要了解的点2 - PHP 一组加密解密算法
- linux同一客户端多个git账号的配置
- centos yum安装PHP5.5,5.6,7.0
- 软件的复杂性与构造定律
- linux 下git使用教程
- 悲观锁
- 一组PHP可逆加密解密算法
- 一个经典的PHP加密解密算法
- 三个php加密解密算法
- 【代码】Android开发收藏功能添加的实现 (2013-08-13 11:15:24)
- php实现cookie加密解密
- (OK)(OK) Android-x86-7.1.1/ kernel 4.4.62
- PHP 短连接生成算法
- 簡單的移动端菜单栏滑屏demo
- 使用fiddler进行genymotion安卓虚拟机手机抓包