国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php實現可逆加密的方法

2024-05-04 23:38:44
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了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. for($j=$i=0;$i<256;$i++){ 
  32. $j=($j+$box[$i]+$rndkey[$i])%256; 
  33. $tmp=$box[$i]; 
  34. $box[$i]=$box[$j]; 
  35. $box[$j]=$tmp; 
  36. for($a=$j=$i=0;$i<$string_length;$i++){ 
  37. $a=($a+1)%256; 
  38. $j=($j+$box[$a])%256; 
  39. $tmp=$box[$a]; 
  40. $box[$a]=$box[$j]; 
  41. $box[$j]=$tmp; 
  42. $result.=chr(ord($string[$i]) ^ ($box[($box[$a]+$box[$j])%256])); 
  43. if($operation=='DECODE'){ 
  44. if((substr($result,0,10)==0||substr($result,0,10)-time()>0)&&substr($result,10,16)==substr(md5(substr($result,26).$keyb),0,16)){ 
  45. returnsubstr($result,26); 
  46. }else
  47. return''
  48. }else
  49. return $keyc.str_replace('=','',base64_encode($result)); 
  50. ?> 

希望本文所述對大家的php程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜丰县| 龙川县| 麟游县| 巴塘县| 安陆市| 海安县| 嵊州市| 湘乡市| 兴仁县| 台山市| 东乡县| 平安县| 准格尔旗| 宜昌市| 綦江县| 桑植县| 临朐县| 江源县| 泽普县| 宿州市| 庆阳市| 惠安县| 涟水县| 辰溪县| 筠连县| 祁连县| 宝鸡市| 旬邑县| 丽江市| 怀来县| 东丽区| 西平县| 兴化市| 青岛市| 巢湖市| 双桥区| 黄大仙区| 津市市| 舒兰市| 湘乡市| 延寿县|