一组PHP可逆加密解密算法
来源:互联网 发布:java replaceall \\\\ 编辑:程序博客网 时间:2024/05/19 13:16
http://www.cnblogs.com/zqifa/p/php-6.html
对于大部分密码加密,我们可以采用md5、sha1等方法。可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密。
对于需要还原的信息,则需要采用可逆的加密解密算法。
下面一组PHP函数是实现此加密解密的方法:
加密算法如下:
function encrypt($data, $key){ $key = md5($key); $x = 0; $str = $char = ''; $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; $str = $char = ''; $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, "\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 一组加密解密算法
- k近邻算法(K-Nearest Neighbor)
- 10-12无缝滚动、DOM、
- BZOJ 2789 Letters
- Material Design(一)史上最全的材料设计控件大全
- 使用python读取excel
- 一组PHP可逆加密解密算法
- SQL Server 2017 on Linux自动安装
- RequireComponent的使用: 当你添加的一个用了RequireComponent组件的脚本,需要的组件将会自动被添加到game object(游戏物体)。这个可以有效的避免组装错误
- python 函数参数传递
- 无限轮播+搜索
- HDU
- 简化版Vector实现
- Codeforces 189D AlgoRace floyd+DP
- java任务--交通工具