PHP 加密和解密


計應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);
?>

運行結果如下圖:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM