php实现可逆加密的方法
发布:smiling 来源: PHP粉丝网 添加日期:2021-06-16 10:57:22 浏览: 评论:0
这篇文章主要介绍了php实现可逆加密的方法,借鉴了discuz的加密原理实现通过密钥进行可逆加密的功能,具有一定参考借鉴价值,需要的朋友可以参考下。
本文实例讲述了php实现可逆加密的方法,分享给大家供大家参考,具体如下:
这里介绍的可以逆转加密类,没有密钥很难破解。
PHP代码如下:
- <?php
- class encryptCalss
- {
- var $key=12;
- function encode($txt){
- for($i=0;$i<strlen($txt);$i++){
- $txt[$i]=chr(ord($txt[$i])+$this->key);
- }
- return $txt=urlencode(base64_encode(urlencode($txt)));
- }
- function decode($txt){
- $txt=urldecode(base64_decode($txt));
- for($i=0;$i<strlen($txt);$i++){
- $txt[$i]=chr(ord($txt[$i])-$this->key);
- }
- return $txt;
- }
- }
- ?>
discuz加密解密:
- <?php
- /**
- *
- * @param string $string 原文或者密文
- * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE
- * @param string $key 密钥
- * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效
- * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
- * @example
- * $a = authcode('abc', 'ENCODE', 'key');
- * $b = authcode($a, 'DECODE', 'key'); // $b(abc)
- *
- * $a = authcode('abc', 'ENCODE', 'key', 3600);
- * $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空
- */
- function authcode($string,$operation='DECODE',$key='',$expiry=0){
- $ckey_length=4;
- $key=md5($key ? $key:"kalvin.cn");
- $keya=md5(substr($key,0,16));
- $keyb=md5(substr($key,16,16));
- $keyc=$ckey_length ? ($operation=='DECODE' ? substr($string,0,$ckey_length):substr(md5(microtime()),-$ckey_length)):'';
- $cryptkey=$keya.md5($keya.$keyc);
- $key_length=strlen($cryptkey);
- $string=$operation=='DECODE' ? base64_decode(substr($string,$ckey_length)):sprintf('%010d',$expiry ? $expiry+time():0).substr(md5($string.$keyb),0,16).$string;
- $string_length=strlen($string);
- $result='';
- $box=range(0,255);
- $rndkey=array();
- for($i=0;$i<=255;$i++){
- $rndkey[$i]=ord($cryptkey[$i%$key_length]);
- }
- for($j=$i=0;$i<256;$i++){
- $j=($j+$box[$i]+$rndkey[$i])%256;
- $tmp=$box[$i];
- $box[$i]=$box[$j];
- $box[$j]=$tmp;
- }
- for($a=$j=$i=0;$i<$string_length;$i++){
- $a=($a+1)%256;
- $j=($j+$box[$a])%256;
- $tmp=$box[$a];
- $box[$a]=$box[$j];
- $box[$j]=$tmp;
- $result.=chr(ord($string[$i]) ^ ($box[($box[$a]+$box[$j])%256]));
- }
- if($operation=='DECODE'){
- if((substr($result,0,10)==0||substr($result,0,10)-time()>0)&&substr($result,10,16)==substr(md5(substr($result,26).$keyb),0,16)){
- returnsubstr($result,26);
- }else{
- return'';
- }
- }else{
- return $keyc.str_replace('=','',base64_encode($result));
- }
- }
- ?>
希望本文所述对大家的php程序设计有所帮助。
Tags: php可逆加密
- 上一篇:php生成二维码
- 下一篇:PHP发送短信代码分享
相关文章
- ·PHP与asp.net C#可共用的可逆加密算法(2014-08-27)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)