首頁 >後端開發 >php教程 >PHP加密擴充庫—Mcrypt擴充庫實例用法

PHP加密擴充庫—Mcrypt擴充庫實例用法

黄舟
黄舟原創
2017-05-25 16:14:004219瀏覽

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;
}
?>

輸出結果為:

PHP加密擴充庫—Mcrypt擴充庫實例用法

注意:這些演算法和模式在實際應用需要用常數來表示,寫的時候分別加上前綴: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>";
?>

輸出結果為:

PHP加密擴充庫—Mcrypt擴充庫實例用法

##下面我們介紹上面實例中出現的幾個函數:

#1.mcrypt_create_iv:

語法格式如下:

string mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] )

使用Mcrypt進行資料加密。解密之前,首先要建立一個初始化向量(簡稱 iv)。建立初始化向量需要兩個參數:size 指定了 iv 的大小,source 為 iv 的來源。 source 可以取以下值:

  • MCRYPT_RAND:系統隨機數。

  • MCRYPT_DEV_RANDOM:讀取目錄/dev/random 中的資料(UNIX系統)。

  • MCRYPT_DEV_URANDOM:讀取目錄/dev/urandom中的資料(UNIX系統)。

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加密函數

2.PHP加密擴充程式庫-Mhash擴充程式庫實例用法詳解



##################################

以上是PHP加密擴充庫—Mcrypt擴充庫實例用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn