当前位置:首页 > PHP教程 > php高级应用 > 列表

php实现可逆加密的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-06-16 10:57:22 浏览: 评论:0 

这篇文章主要介绍了php实现可逆加密的方法,借鉴了discuz的加密原理实现通过密钥进行可逆加密的功能,具有一定参考借鉴价值,需要的朋友可以参考下。

本文实例讲述了php实现可逆加密的方法,分享给大家供大家参考,具体如下:

这里介绍的可以逆转加密类,没有密钥很难破解。

PHP代码如下:

  1. <?php 
  2. class encryptCalss 
  3. var $key=12; 
  4. function encode($txt){ 
  5. for($i=0;$i<strlen($txt);$i++){ 
  6. $txt[$i]=chr(ord($txt[$i])+$this->key); 
  7. return $txt=urlencode(base64_encode(urlencode($txt))); 
  8. function decode($txt){ 
  9. $txt=urldecode(base64_decode($txt)); 
  10. for($i=0;$i<strlen($txt);$i++){ 
  11. $txt[$i]=chr(ord($txt[$i])-$this->key); 
  12. return $txt
  13. ?> 

discuz加密解密:

  1. <?php 
  2. /** 
  3.  *  
  4.  * @param string $string 原文或者密文 
  5.  * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE 
  6.  * @param string $key 密钥 
  7.  * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效 
  8.  * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文 
  9.  * @example  
  10.  *  $a = authcode('abc', 'ENCODE', 'key'); 
  11.  *  $b = authcode($a, 'DECODE', 'key'); // $b(abc) 
  12.  *  
  13.  *  $a = authcode('abc', 'ENCODE', 'key', 3600); 
  14.  *  $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空 
  15.  */ 
  16. function authcode($string,$operation='DECODE',$key='',$expiry=0){ 
  17.   $ckey_length=4; 
  18.   $key=md5($key ? $key:"kalvin.cn"); 
  19.   $keya=md5(substr($key,0,16)); 
  20.   $keyb=md5(substr($key,16,16)); 
  21.   $keyc=$ckey_length ? ($operation=='DECODE' ? substr($string,0,$ckey_length):substr(md5(microtime()),-$ckey_length)):''
  22.   $cryptkey=$keya.md5($keya.$keyc); 
  23.   $key_length=strlen($cryptkey); 
  24.   $string=$operation=='DECODE' ? base64_decode(substr($string,$ckey_length)):sprintf('%010d',$expiry ? $expiry+time():0).substr(md5($string.$keyb),0,16).$string
  25.   $string_length=strlen($string); 
  26.   $result=''
  27.   $box=range(0,255); 
  28.   $rndkey=array(); 
  29.   for($i=0;$i<=255;$i++){ 
  30.     $rndkey[$i]=ord($cryptkey[$i%$key_length]); 
  31.   } 
  32.   for($j=$i=0;$i<256;$i++){ 
  33.     $j=($j+$box[$i]+$rndkey[$i])%256; 
  34.     $tmp=$box[$i]; 
  35.     $box[$i]=$box[$j]; 
  36.     $box[$j]=$tmp
  37.   } 
  38.   for($a=$j=$i=0;$i<$string_length;$i++){ 
  39.     $a=($a+1)%256; 
  40.     $j=($j+$box[$a])%256; 
  41.     $tmp=$box[$a]; 
  42.     $box[$a]=$box[$j]; 
  43.     $box[$j]=$tmp
  44.     $result.=chr(ord($string[$i]) ^ ($box[($box[$a]+$box[$j])%256])); 
  45.   } 
  46.   if($operation=='DECODE'){ 
  47.     if((substr($result,0,10)==0||substr($result,0,10)-time()>0)&&substr($result,10,16)==substr(md5(substr($result,26).$keyb),0,16)){ 
  48.       returnsubstr($result,26); 
  49.     }else
  50.       return''
  51.     } 
  52.   }else
  53.     return $keyc.str_replace('=','',base64_encode($result)); 
  54.   } 
  55. ?> 

希望本文所述对大家的php程序设计有所帮助。

Tags: php可逆加密

分享到: