計應134(實驗班) 鄭壽奎php
1、crypt()函數單向加密函數
語法格式:加密
String crypt(string str[, string salt]);spa
參數str是須要加密的值,salt是干擾串,若是把salt省略就會隨機生成一個干擾串3d
設置干擾串和不設置干擾串的區別:code
設置干擾串以後的值是一直不會變的blog
不設置干擾串以後的值是隨機的,每一次都不同md5
代碼以下:string
<?php $str="這是個值"; echo '加密前的值:'.$str."<br>"; $jiami=crypt($str); echo '沒有干擾串加密後的值:'.$jiami."<br>"; $jia=crypt($str,"ab"); echo '添加干擾串"ab"加密後的值:'.$jia."<br>"; ?>
第一次運行結果以下圖:it
第二次運行結果以下圖:
crypt()函數加密是單向加密的,若是不加干擾串,那麼每次加密的結果都是不同的,可是加了干擾串以後能夠發現,每次的值都是同樣的。
因此對加密後的數據進行判斷就須要在加密以前加上干擾串
2、md5()函數加密
語法格式:
string md5(string str[, bool raw_output]);
參數str是須要加密的數據,raw_output的值是true和false,默認爲false,若是爲true的是後,那麼函數就會返回一個二進制形式的密文
md5()函數加密的密文是一直不會變的
代碼:
<?php $str="這是個值"; echo '加密前的值:'.$str."<br>"; $jiami=md5($str); echo '默認加密後的值:'.$jiami."<br>"; $jiami=md5($str,true); echo 'true加密後的值:'.$jiami."<br>"; ?>
運行結果以下圖:
3、sha1()函數加密
語法格式:
string sha1(string str[, bool raw_output]);
參數str是須要加密的數據,raw_output默認false,函數返回一個40位的十六進制數,true 返回20的二進制數
sha1()函數加密後的密文是不會變的
代碼:
<?php $str="這是個值"; echo '加密前的值:'.$str."<br>"; $jiami=sha1($str); echo '默認加密後的值:'.$jiami."<br>"; $jiami=sha1($str,true); echo 'true加密後的值:'.$jiami."<br>"; ?>
運行結果以下圖:
4、加密和解密
代碼:
<?php //加密 function encode($string = '', $skey = 'cxphp') { $strArr = str_split(base64_encode($string)); $strCount = count($strArr); foreach (str_split($skey) as $key => $value) $key < $strCount && $strArr[$key].=$value; return str_replace(array('=', '+', '/'), array('O0O0O', 'o000o', 'oo00o'), join('', $strArr)); } //解密 function decode($string = '', $skey = 'cxphp') { $strArr = str_split(str_replace(array('O0O0O', 'o000o', 'oo00o'), array('=', '+', '/'), $string), 2); $strCount = count($strArr); foreach (str_split($skey) as $key => $value) $key <= $strCount && isset($strArr[$key]) && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0]; return base64_decode(join('', $strArr)); } $str = '四大古典風格'; echo "string : " . $str . " <br />"; echo "encode : " . ($enstring = encode($str)) . '<br />'; echo "decode : " . decode($enstring); ?>
運行結果以下圖: