PHP加密擴充庫—Mcrypt擴充庫
#在本文開始正文開始之前,我們先來了解什麼是PHP加密擴充庫:PHP中不但幾種加密函數(md5,crypt,sha1),在此之外,PHP還有一些功能比較全面的加密擴充庫!就好比php本來不支援操作某種功能,但在新版本想對它提供支援,就以擴展的方式來提供,這樣,我們在配置php時,如果我們不用此功能,我們就可以讓php不加載他.從而節省伺服器資源.提供其效能。
在先前的三篇文章《PHP加密函數—crypt()函數加密》、《PHP加密函數—md5()函數加密》以及《PHP加密函數—sha1()函數加密》中介紹了PHP加密函數,那麼接下來我們要來跟大家介紹PHP加密擴充庫!
PHP加密擴充函式庫有兩種,Mcrypt 和Mhash兩種擴充函式庫,這篇文章我們先介紹Mcrypt!
1.Mcrypt函式庫安裝
mcypt是一個功能十分強大的加密演算法擴充庫。在標準的PHP安裝過程中並沒有把Mcrypt安裝上,但PHP的主目錄下包含了libmcrypt.dll文件,所以我們只用將PHP配置文件中的這行extension=php_mcrypt.dll前面的分號「; 「去掉,然後重啟伺服器就可以使用這個擴充庫了。
2.Mcrypt庫常數
mcrypt庫支援20多種的加密演算法,以及8 種加密模式,我們可以直接使用函數mcrypt_list_algorithms() 和mcrypt_list_modes( )來查看,具體程式碼如下:
<?php $atr = mcrypt_list_algorithms(); //函数返回 Mcrypt支持的加密算法数组 echo "支持算法有:"; foreach ($atr as $atr_value){ echo "<br>".$atr_value; } $arr = mcrypt_list_modes(); //函数返回 Mcrypt支持的加密模式数组 echo "<p>支持加密模式有:"; foreach ($arr as $arr_value){ echo "<br>".$arr_value; } ?>
輸出結果為:
注意:這些演算法和模式在實際應用需要用常數來表示,寫的時候分別加上前綴:MCRYPT_和MCRYPT_MODE_來表示,實例:
TWOFISH演算法表示為:MCRYPT_TWOFISH。
CBC加密模式表示為: MCRYPT_MODE_CBC。
3.Mcrypt應用程式
使用 Mcrypt 進行加密和解密不想使用md5(),sha1()等函數,直接呼叫就可以了。為了讓大家能清楚的了解Mcrypt的工作流程,以下我們直接用程式碼介紹,具體程式碼如下:
<?php header("Content-Type:text/html; charset=utf-8"); $str = "被加密的内容:PHH中文网www.php.cn"; //加密文本 $key = "key:111"; //密钥 $cipher = MCRYPT_DES; //密码类型 $modes = MCRYPT_MODE_ECB; //密码模式 $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher,$modes),MCRYPT_RAND); //初始化向量 echo "加密前:".$str."<p>"; $str_encrypt = mcrypt_encrypt($cipher,$key,$str,$modes,$iv); //加密函数 echo "加密后:".$str_encrypt."<p>"; $str_decrypt =mcrypt_decrypt($cipher,$key,$str_encrypt,$modes,$iv); //解密函数 echo "还原:".$str_decrypt."<p>"; ?>
輸出結果為:
##下面我們介紹上面實例中出現的幾個函數:
#1.mcrypt_create_iv:
語法格式如下:string mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] )使用Mcrypt進行資料加密。解密之前,首先要建立一個初始化向量(簡稱 iv)。建立初始化向量需要兩個參數:size 指定了 iv 的大小,source 為 iv 的來源。 source 可以取以下值:
2.mcrypt_get_iv_size:
語法格式:int mcrypt_get_iv_size ( string $cipher , string $mode )此函數傳回的初始化向量(iv)的大小。函數中的兩個參數是前面剛介紹的加密演算法(cipher)和加密模式(mode)。
3.mcrypt_encrypt:
語法格式如下:string mcrypt_encrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )初始化向量後,既可以使用mcrypt_encrypt()加密函數對資料進行加密,此函數的5 個參數的意義分別如下:(1)cipher:加密演算法。上例中為變數$cipher 這裡的加密演算法可以和初始化向量中的加密演算法不一樣。 (2)key: 金鑰。上例中的變數$key。 (3)mode: 加密模式。 (4)iv: 初始化向量。
4.mcrypt_decrypt
語法格式如下:string mcrypt_decrypt ( string $cipher , string $key , string $data , string $mode [, string $iv ] )解密函數 mcrypt_decrypt()和加密函數 mcrypt_encrypt()的參數幾乎是一樣的。唯一不一樣的是參數data,這裡data 為需要解密的數據,而不是原始資料。
說明:加密函數和解密函數中的 cipher,key以及mode 參數必須一致,否則資料不會被還原。
下一篇我們繼續介紹PHP加密擴充庫:Mhash擴充庫,請閱讀《PHP加密擴充庫—Mhash擴充庫》!
【相關推薦】1. 相關專題推薦:《PHP加密函數》
以上是PHP加密擴充庫—Mcrypt擴充庫實例用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!