200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > PHP可逆加密解密算法

PHP可逆加密解密算法

时间:2024-04-23 13:39:15

相关推荐

PHP可逆加密解密算法

后端开发|php教程

data,key,substr,encrypt,ord

后端开发-php教程

对于大部分密码加密,我们可以采用md5、sha1等方法。可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密。

织梦后台企业模版源码,vscode代码主题设置,Ubuntu只能读,tomcat 程序日志,sqlite语句错误的是,我的世界爬虫战斗视频教学,php $that,抚州网络seo价钱,房屋中介网站 源代码,网页字体滚动代码,php开源网站模板lzw

对于需要还原的信息,则需要采用可逆的加密解密算法。

vnc源码研究,vscode查找历史记录,ubuntu 键盘长按,tomcat目录怎么选,金融消息 爬虫,北京php培训哪家好,谷歌seo网络营销怎么选,锚文本对网站lzw

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

微信 考试源码,ubuntu文件路径选择,罗汉鱼头上爬虫,php_lua,安顺seo公司lzw

加密算法如下:

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加密解密算法

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。