小編給大家分享一下PHP中使用Mhash函數的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
這次我們要學習的又是一個 Hash 加密擴展。不過這個擴展 Mhash 已經集成在了 Hash 擴展中。同時也需要注意的是,這個擴展已經不推薦使用了,我們應該直接使用 Hash 擴展中的函數來進行 Hash 加密操作。所以,我們今天仍然是以學習為目的的進行了解。關于 Hash 擴展的內容,我們可以查看之前的文章:PHP的Hash信息摘要擴展框架 。
$hash = mhash(MHASH_MD5, "測試Mhash"); echo $hash, PHP_EOL; echo bin2hex($hash), PHP_EOL; // /?8?><???P4q?j? // 2fcb38e93e3cc8dba09f503471846a9d $hash = hash('md5', "測試Mhash"); echo $hash, PHP_EOL; // 2fcb38e93e3cc8dba09f503471846a9d $hash = mhash(MHASH_MD5, "測試Mhash", 'hmac secret'); echo $hash, PHP_EOL; echo bin2hex($hash), PHP_EOL; // ?k?<F?m ?OM???? // b86bb83c46b76d09be4f4daf18ebfe85
從代碼中可以看出,mhash() 函數和 hash() 的使用非常像,當然,他們的作用也是一樣的。不過,mhash() 函數加密出來的直接是二進制的,我們將這個內容通過 bin2hex() 轉成 16 進制之后就可以看到和普通的 hash() 函數加密的結構是完全相同的了。
在進行 hmac 加密的時候直接在第三個參數上添加 key 就可以了。
當然,就像 Hash 加密一樣,Mhash 加密也是可以選擇不同的算法的。我們也是直接使用相關的函數就可以看到當前環境中所支持的加密算法。
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 。其實就是我們遍歷的這些內容在前面加上 MHASH_ 就可以了。具體支持的常量列表我們可以在官方手冊中找到,在這里就不進行復制粘貼了。
另外,Mhash 還為我們提供了一個非常方便的 Salted S2K 算法可以用來方便地生成一套非常方便地密碼加密內容。
// OpenPGP 指定的 Salted S2K 算法 $hashPassword = mhash_keygen_s2k(MHASH_SHA1, '我的密碼', random_bytes(2), 4); echo $hashPassword, PHP_EOL; echo bin2hex($hashPassword), PHP_EOL; // ?-!= // 101ab899
當然,這個算法也是比較安全的,有 salt 參數,并且它可以指定返回的數據長度。它返回的也是二進制的數據,如果需要保存標準的文本內容也需要將其轉化為 16 進制的形式。不過相對來說,我反而覺得這種直接生成二進制內容的還更安全一些
以上是“PHP中使用Mhash函數的方法”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。