對於大部分密碼加密,我們可以採用md5、sha1等方法。可以有效防止資料泄露,但是這些方法僅適用於無需還原的資料加密。
對於需要還原的資訊,則需要採用可逆的加密解密演算法。
下面一組PHP函數是實現此加密解密的方法:
密碼編譯演算法如下:
代碼如下 |
複製代碼 |
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加密解密演算法
從上述結果可以看出,這是一組可逆的加密解密演算法,可以用於部分需要還原的資料加密。