一组PHP可逆加密解密算法
2016-06-01 16:42
459 查看
对于大部分密码加密,我们可以采用md5、sha1等方法。可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密。
对于需要还原的信息,则需要采用可逆的加密解密算法。
下面一组PHP函数是实现此加密解密的方法:
加密算法如下:
解密算法如下:
上述加密解密的过程均需要用到一个加密密钥(即参数$key)。
上述将输出类似如下结果:
gniCSOzZG+HnS9zcFea7SefNGhXF
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, "\n", $decrypt;
上述将输出类似如下结果:
gniCSOzZG+HnS9zcFea7SefNGhXF
PHP加密解密算法
从上述结果可以看出,这是一组可逆的加密解密算法,可以用于部分需要还原的数据加密。
相关文章推荐
- php安装composer是报错解决
- ubuntu服务器中安装设置ftp服务器
- Windows下搭建PHP开发环境-WEB服务器
- 关于初学TP的一点小小感悟
- PHP文件上传进度处理方法
- [转]日请求过亿的Web系统PHP7升级实践
- php引用赋值& 和传递赋值
- PHP基础笔记(01)
- PHP Warning: mkdir() [function.mkdir]: Permission denied in解决方法
- PHP菜鸟如何开始学习PHP语言
- PHP邮箱验证示例教程
- crontab执行php的问题
- 本地环境phpStorm10+XDebug配置和断点调试
- php处理emoji表情方法集合
- php缓存机制
- 考虑 PHP 5.0~5.6 各版本兼容性的 cURL 文件上传
- 记录一下我的PHP成长路线
- jmeter 构建一个FTP测试计划
- 2.php的设计模式:单例模式
- yii2 资源目录问题