溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP中使用Mhash函數的方法

發布時間:2021-06-03 11:39:20 來源:億速云 閱讀:166 作者:小新 欄目:編程語言

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

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_ 就可以了。具體支持的常量列表我們可以在官方手冊中找到,在這里就不進行復制粘貼了。

Salted S2K 算法生成密碼摘要

另外,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函數的方法”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女