計應134(實驗班) 鄭壽奎
一、crypt()函數單向加密
語法格式:
String crypt(string str[, string salt]);
參數str是需要加密的值,salt是干擾串,如果把salt省略就會隨機生成一個干擾串
設置干擾串和不設置干擾串的區別:
設置干擾串之后的值是一直不會變的
不設置干擾串之后的值是隨機的,每一次都不一樣
代碼如下:
<?php $str="這是個值"; echo '加密前的值:'.$str."<br>"; $jiami=crypt($str); echo '沒有干擾串加密后的值:'.$jiami."<br>"; $jia=crypt($str,"ab"); echo '添加干擾串"ab"加密后的值:'.$jia."<br>"; ?>
第一次運行結果如下圖:
第二次運行結果如下圖:
crypt()函數加密是單向加密的,如果不加干擾串,那么每次加密的結果都是不一樣的,但是加了干擾串之后可以發現,每次的值都是一樣的。
所以對加密后的數據進行判斷就需要在加密之前加上干擾串
二、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>"; ?>
運行結果如下圖:
三、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>"; ?>
運行結果如下圖:
四、加密和解密
代碼:
<?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); ?>
運行結果如下圖: