今天我們來(lái)聊一下PHP中常用的哈希(HASH)加密技術(shù)之一- HMAC。HMAC是從一般哈希算法發(fā)展而來(lái)的,關(guān)于hash加密的用途和作用已經(jīng)被廣泛的介紹過,這里就不再贅述。
在PHP中,使用HMAC加密,需要使用hash_hmac($algorithm, $data, $key, $raw_output)函數(shù)。其中:
$algorithm: 哈希算法,如SHA256等; $data:待加密的數(shù)據(jù); $key:加密密鑰; $raw_output:輸出格式,true表示二進(jìn)制格式,false表示十六進(jìn)制格式(默認(rèn)false)。
下面我們結(jié)合實(shí)例來(lái)介紹HMAC加密:
$key = "This is a key"; $data = "This is some data"; $hash = hash_hmac("sha256", $data, $key); echo "加密后的值:" . $hash;
上面的代碼將待加密數(shù)據(jù)$data使用SHA256哈希算法和密鑰$key進(jìn)行加密,得到的結(jié)果為:
c4e68efdebb90aba452ecb0f8c635763cd74de1d8631f69f473586c78b55db4e
HMAC加密的一個(gè)重要應(yīng)用場(chǎng)景就是用于防止消息篡改。
例如:在網(wǎng)絡(luò)傳輸過程中,可能會(huì)有惡意第三方干擾,篡改傳輸?shù)南?nèi)容,從而達(dá)到非法盜取、篡改信息的目的。如果沒有措施對(duì)付這種攻擊,將會(huì)造成不可估量的損失。
在此場(chǎng)景下,HMAC就是一個(gè)解決方案。使用HMAC+加密密鑰,進(jìn)行消息內(nèi)容的加密和基于密鑰的認(rèn)證,確保消息未被篡改。下面我們看一個(gè)例子:
$data = "This is some data"; $key = "This is a key"; $hash = hash_hmac("sha256", $data, $key); $message = $data . "|" . $hash; // 將消息數(shù)據(jù)$message發(fā)送到對(duì)方 // 對(duì)方收到數(shù)據(jù)后,進(jìn)行消息內(nèi)容和認(rèn)證碼校驗(yàn): $arr = explode("|", $message); $messageData = $arr[0]; // 內(nèi)容 $messageHash = $arr[1]; // 認(rèn)證碼 // 重新計(jì)算認(rèn)證碼 $newHash = hash_hmac("sha256", $messageData, $key); // 比對(duì)認(rèn)證碼 if($newHash == $messageHash) { echo "消息無(wú)篡改"; } else { echo "消息已被篡改,請(qǐng)注意安全!"; }
上面的代碼用$|分隔了消息和HMAC,對(duì)方在接收消息后,重新計(jì)算得到HMAC,和接收到的HMAC對(duì)比來(lái)判斷消息是否被篡改。
由此可見,HMAC加密技術(shù)非常適合在網(wǎng)絡(luò)傳輸、交互等場(chǎng)景下,用于保護(hù)消息的完整性和安全,可以為應(yīng)用程序提供更多的安全保障。