1. 程式人生 > >PHP可逆加密解密演算法

PHP可逆加密解密演算法

對於大部分密碼加密,我們可以採用md5、sha1等方法。可以有效防止資料洩露,但是這些方法僅適用於無需還原的資料加密。

對於需要還原的資訊,則需要採用可逆的加密解密演算法。

下面一組PHP函式是實現此加密解密的方法:

加密演算法如下:

Php程式碼  收藏程式碼
  1. function encrypt($data$key)  
  2. {  
  3.     $key    =   md5($key);  
  4.     $x      =   0;  
  5.     $len    =   strlen($data);  
  6.     $l      =   strlen($key);  
  7.     for ($i = 0; $i
     < $len$i++)  
  8.     {  
  9.         if ($x == $l)   
  10.         {  
  11.             $x = 0;  
  12.         }  
  13.         $char .= $key{$x};  
  14.         $x++;  
  15.     }  
  16.     for ($i = 0; $i < $len$i++)  
  17.     {  
  18.         $str .= chr(ord($data{$i}) + (ord($char{$i})) % 256);  
  19.     }  
  20.     return base64_encode($str);  
  21. }  

解密演算法如下:

Php程式碼  收藏程式碼
  1. function decrypt($data$key)  
  2. {  
  3.     $key = md5($key);  
  4.     $x = 0;  
  5.     $data = base64_decode($data);  
  6.     $len = strlen($data);  
  7.     $l = strlen($key);  
  8.     for ($i = 0; $i < $len$i++)  
  9.     {  
  10.         if ($x == $l)   
  11.         {  
  12.             $x = 0;  
  13.         }  
  14.         $char .= substr($key$x, 1);  
  15.         $x++;  
  16.     }  
  17.     for ($i = 0; $i < $len$i++)  
  18.     {  
  19.         if (ord(substr($data$i, 1)) < ord(substr($char$i, 1)))  
  20.         {  
  21.             $str .= chr((ord(substr($data$i, 1)) + 256) - ord(substr($char$i, 1)));  
  22.         }  
  23.         else  
  24.         {  
  25.             $str .= chr(ord(substr($data$i, 1)) - ord(substr($char$i, 1)));  
  26.         }  
  27.     }  
  28.     return $str;  
  29. }  

上述加密解密的過程均需要用到一個加密金鑰(即引數$key)。

Php程式碼  收藏程式碼
  1. $data = 'PHP加密解密演算法';        // 被加密資訊  
  2. $key = '123';                   // 金鑰  
  3. $encrypt = encrypt($data$key);  
  4. $decrypt = decrypt($encrypt$key);  
  5. echo $encrypt"\n"$decrypt;  

上述將輸出類似如下結果:

gniCSOzZG+HnS9zcFea7SefNGhXF


PHP加密解密演算法

從上述結果可以看出,這是一組可逆的加密解密演算法,可以用於部分需要還原的資料加密。