文章詳情頁(yè)
PHP加密函數(shù)與解密函數(shù)詳解
瀏覽:90日期:2022-06-06 09:09:02
去網(wǎng)上找了下。
Php常用的加密函數(shù)有
MD5加密(不可逆)、Crypt加密(不可逆)、Sha1加密(不可逆)、Urlencode加密(可逆)
base64編碼加密(可逆)
還是見識(shí)的太少,這其中我只用過(guò)MD5和base64
最常用的還是MD5 ,MD5的加密雖不可逆,但一些簡(jiǎn)單的 兩次MD5加密的字符串,花點(diǎn)錢還是能解密的。
為了防止解密一般都是對(duì)字符串進(jìn)行MD5加密,在加密過(guò)得字符串上加一個(gè)固定字符串,再進(jìn)行MD5加密。(感覺好麻煩……)
分享一個(gè)自用的加密和解密函數(shù)
/** * 加密 * @param string $string 要加密或解密的字符串 * @param string $operation 加密 "" 解密 DECODE * @param string $key密鑰,加密解密時(shí)保持一致 * @param int $expiry 有效時(shí)長(zhǎng),單位:秒 * @return string */ function encrypt_code($string, $expiry = 0, $key = "1234567890") { $ckey_length = 1; $key = md5($key ? $key : UC_KEY); //加密解密時(shí)這個(gè)是不變的 $keya = md5(substr($key, 0, 16)); //加密解密時(shí)這個(gè)是不變的 $keyb = md5(substr($key, 16, 16)); //加密解密時(shí)這個(gè)是不變的 $keyc = $ckey_length ? substr(md5(microtime()), -$ckey_length) : ""; $cryptkey = $keya . md5($keya . $keyc); //64 $key_length = strlen($cryptkey); //64 $string =sprintf("%010d", $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb), 0, 16) . $string; $string_length = strlen($string); $result = ""; $box = range(0, 255); $rndkey = array(); for ($i = 0; $i <= 255; $i++) { //字母表 64位后重復(fù) 數(shù)列 范圍為48~122 $rndkey[$i] = ord($cryptkey[$i % $key_length]); } for ($j = $i = 0; $i < 256; $i++) { //這里是一個(gè)打亂算法 $j = ($j + $box[$i] + $rndkey[$i]) % 256; $tmp = $box[$i]; $box[$i] = $box[$j]; $box[$j] = $tmp; } for ($a = $j = $i = 0; $i < $string_length; $i++) { $result .= chr(ord($string[$i]) ^ ($box[$i])); } $str = $keyc . str_replace("=", "", base64_encode($result)); // $str =htmlentities($str, ENT_QUOTES, "UTF-8"); // curl 訪問(wèn)出錯(cuò) return $str ; } /** * 解密 * @param string $string 要加密或解密的字符串 * @param string $operation 加密 "" 解密 DECODE * @param string $key密鑰,加密解密時(shí)保持一致 * @param int $expiry 有效時(shí)長(zhǎng),單位:秒 * @return string */ function encrypt_decode($string, $expiry = 0,$key = "1234567890") { $ckey_length = 1; $key = md5($key ? $key : UC_KEY); //加密解密時(shí)這個(gè)是不變的 $keya = md5(substr($key, 0, 16)); //加密解密時(shí)這個(gè)是不變的 $keyb = md5(substr($key, 16, 16)); //加密解密時(shí)這個(gè)是不變的 $keyc = $ckey_length ? substr($string, 0, $ckey_length) : ""; $cryptkey = $keya . md5($keya . $keyc); //64 $key_length = strlen($cryptkey); //64 $string = base64_decode(substr($string, $ckey_length)) ; $string_length = strlen($string); $result = ""; $box = range(0, 255); $rndkey = array(); for ($i = 0; $i <= 255; $i++) { //字母表 64位后重復(fù) 數(shù)列 范圍為48~122 $rndkey[$i] = ord($cryptkey[$i % $key_length]); } for ($j = $i = 0; $i < 256; $i++) { //這里是一個(gè)打亂算法 $j = ($j + $box[$i] + $rndkey[$i]) % 256; $tmp = $box[$i]; $box[$i] = $box[$j]; $box[$j] = $tmp; } for($a = $j = $i = 0; $i < $string_length; $i++) { $result .= chr(ord($string[$i]) ^ ($box[$i])); } if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb), 0, 16)) { return substr($result, 26); }else{ return false; } }
注:加密函數(shù)與解密函數(shù)中的 $key 必須完全相同。
到此這篇關(guān)于PHP加密函數(shù)與解密函數(shù)詳解的文章就介紹到這了,更多相關(guān)PHP加密解密函數(shù)內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!
標(biāo)簽:
PHP
排行榜
