標籤:srand 解密 參考 and ret 方法 mic ++ function
在開發應用過程中我們經常會涉及一些連結或參數或cookie的加密解密,由於php自身提供的md5函數無法復原,因此md5隻適用於類似密碼加密的地方,而cookie加密則有局限性,下面為大家提供一種加密解密函數方法,供大家參考:
<?php//加密函數function passport_encrypt($txt, $key) {srand((double)microtime() * 1000000);$encrypt_key = md5(rand(0, 32000));$ctr = 0;$tmp = ‘‘;for($i = 0;$i < strlen($txt); $i++) { $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; $tmp .= $encrypt_key[$ctr].($txt[$i] ^ $encrypt_key[$ctr++]);}return base64_encode(passport_key($tmp, $key));}//解密函數function passport_decrypt($txt, $key) {$txt = passport_key(base64_decode($txt), $key);$tmp = ‘‘;for($i = 0;$i < strlen($txt); $i++) { $md5 = $txt[$i]; $tmp .= $txt[++$i] ^ $md5;}return $tmp;}function passport_key($txt, $encrypt_key) {$encrypt_key = md5($encrypt_key);$ctr = 0;$tmp = ‘‘;for($i = 0; $i < strlen($txt); $i++) { $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr; $tmp .= $txt[$i] ^ $encrypt_key[$ctr++];}return $tmp;}echo passport_encrypt(‘安德兔‘,‘andetu‘);echo ‘<br>‘;echo passport_decrypt(‘UbgE+lfWVLMH4wC9Db8EjFXF‘,‘andetu‘);
PHP帶參數可逆的加密解密函數,可用於cookie的加密解密