溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP中使用Mhash函數(shù)的方法

發(fā)布時(shí)間:2021-06-03 11:39:20 來源:億速云 閱讀:120 作者:小新 欄目:編程語言

小編給大家分享一下PHP中使用Mhash函數(shù)的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

PHP的Mhash擴(kuò)展函數(shù)的學(xué)習(xí)

這次我們要學(xué)習(xí)的又是一個(gè) Hash 加密擴(kuò)展。不過這個(gè)擴(kuò)展 Mhash 已經(jīng)集成在了 Hash 擴(kuò)展中。同時(shí)也需要注意的是,這個(gè)擴(kuò)展已經(jīng)不推薦使用了,我們應(yīng)該直接使用 Hash 擴(kuò)展中的函數(shù)來進(jìn)行 Hash 加密操作。所以,我們今天仍然是以學(xué)習(xí)為目的的進(jìn)行了解。關(guān)于 Hash 擴(kuò)展的內(nèi)容,我們可以查看之前的文章:PHP的Hash信息摘要擴(kuò)展框架 。

加密散列函數(shù)的使用

$hash = mhash(MHASH_MD5, "測(cè)試Mhash");
echo $hash, PHP_EOL;
echo bin2hex($hash), PHP_EOL;
// /?8?><???P4q?j?
// 2fcb38e93e3cc8dba09f503471846a9d

$hash = hash('md5', "測(cè)試Mhash");
echo $hash, PHP_EOL;
// 2fcb38e93e3cc8dba09f503471846a9d

$hash = mhash(MHASH_MD5, "測(cè)試Mhash", 'hmac secret');
echo $hash, PHP_EOL;
echo bin2hex($hash), PHP_EOL;
// ?k?<F?m ?OM????
// b86bb83c46b76d09be4f4daf18ebfe85

從代碼中可以看出,mhash() 函數(shù)和 hash() 的使用非常像,當(dāng)然,他們的作用也是一樣的。不過,mhash() 函數(shù)加密出來的直接是二進(jìn)制的,我們將這個(gè)內(nèi)容通過 bin2hex() 轉(zhuǎn)成 16 進(jìn)制之后就可以看到和普通的 hash() 函數(shù)加密的結(jié)構(gòu)是完全相同的了。

在進(jìn)行 hmac 加密的時(shí)候直接在第三個(gè)參數(shù)上添加 key 就可以了。

遍歷所有支持的算法類型

當(dāng)然,就像 Hash 加密一樣,Mhash 加密也是可以選擇不同的算法的。我們也是直接使用相關(guān)的函數(shù)就可以看到當(dāng)前環(huán)境中所支持的加密算法。

echo mhash_count(), PHP_EOL;

$nr = mhash_count(); // 33

for ($i = 0; $i <= $nr; $i++) {
    echo sprintf("Hash:%s,塊大小為: %d\n",
        mhash_get_hash_name($i),
        mhash_get_block_size($i));
}
// Hash:CRC32,塊大小為: 4
// Hash:MD5,塊大小為: 16
// Hash:SHA1,塊大小為: 20
// Hash:HAVAL256,塊大小為: 32
// Hash:,塊大小為: 0
// Hash:RIPEMD160,塊大小為: 20
// Hash:,塊大小為: 0
// Hash:TIGER,塊大小為: 24
// Hash:GOST,塊大小為: 32
// Hash:CRC32B,塊大小為: 4
// Hash:HAVAL224,塊大小為: 28
// Hash:HAVAL192,塊大小為: 24
// Hash:HAVAL160,塊大小為: 20
// Hash:HAVAL128,塊大小為: 16
// Hash:TIGER128,塊大小為: 16
// Hash:TIGER160,塊大小為: 20
// Hash:MD4,塊大小為: 16
// Hash:SHA256,塊大小為: 32
// Hash:ADLER32,塊大小為: 4
// Hash:SHA224,塊大小為: 28
// Hash:SHA512,塊大小為: 64
// Hash:SHA384,塊大小為: 48
// Hash:WHIRLPOOL,塊大小為: 64
// Hash:RIPEMD128,塊大小為: 16
// Hash:RIPEMD256,塊大小為: 32
// Hash:RIPEMD320,塊大小為: 40
// Hash:,塊大小為: 0
// Hash:SNEFRU256,塊大小為: 32
// Hash:MD2,塊大小為: 16
// Hash:FNV132,塊大小為: 4
// Hash:FNV1A32,塊大小為: 4
// Hash:FNV164,塊大小為: 8
// Hash:FNV1A64,塊大小為: 8
// Hash:JOAAT,塊大小為: 4

在 PHP 中也提供了非常多的常量來代表這些算法,比如在前一段代碼中我們使用的 MHASH_MD5 。其實(shí)就是我們遍歷的這些內(nèi)容在前面加上 MHASH_ 就可以了。具體支持的常量列表我們可以在官方手冊(cè)中找到,在這里就不進(jìn)行復(fù)制粘貼了。

Salted S2K 算法生成密碼摘要

另外,Mhash 還為我們提供了一個(gè)非常方便的 Salted S2K 算法可以用來方便地生成一套非常方便地密碼加密內(nèi)容。

// OpenPGP 指定的 Salted S2K 算法
$hashPassword = mhash_keygen_s2k(MHASH_SHA1, '我的密碼', random_bytes(2), 4);
echo $hashPassword, PHP_EOL;
echo bin2hex($hashPassword), PHP_EOL;
// ?-!=
// 101ab899

當(dāng)然,這個(gè)算法也是比較安全的,有 salt 參數(shù),并且它可以指定返回的數(shù)據(jù)長(zhǎng)度。它返回的也是二進(jìn)制的數(shù)據(jù),如果需要保存標(biāo)準(zhǔn)的文本內(nèi)容也需要將其轉(zhuǎn)化為 16 進(jìn)制的形式。不過相對(duì)來說,我反而覺得這種直接生成二進(jìn)制內(nèi)容的還更安全一些

以上是“PHP中使用Mhash函數(shù)的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI