首頁  >  文章  >  後端開發  >  php之crc32踩坑解決

php之crc32踩坑解決

*文
*文原創
2017-12-27 09:42:494785瀏覽

php的crc32會遇到哪些坑?該如何解決?本文主要介紹了php的crc32函數使用時需要注意的問題。希望對大家使用crc32有幫助。

前幾天寫了一個分錶程序,用的hash演算法是crc32.分錶的函數如下:

function _getHash($username)
    {
        $hash = crc32($username) % 512;
        return $hash;
    }

    function _getTable($username)
    {
        $hash = self::_getHash($username);
        return 'user_' . $hash;
    }

 


首先在本地32位元window機上產生好資料並插入對應的表中。但再把程式和資料傳到伺服器上(64為linux),發現查不到資料。經過排查後發現,原來伺服器上crc32的結果和本地不同。再查php手冊才知,crc32的介面原來和機器有關。
php手冊的描述:

Because PHP's integer type is signed many crc32 checksums will result in negative integers on 32bit platforms. On 64bit installations all crc32() results will be positive integers though.


crc32回傳的結果會在32位元機器上產生溢出,所以結果可能為負數。而在64位元機上不會溢出,所以總是正值。

CRC演算法是按字長位數bit計算的。

crc32函數會依照php中的兩個常數參考計算PHP_INT_SIZE,PHP_INT_MAX
這兩個常數的定義:
整數型數的字長和平台有關,儘管通常最大值是大約二十億(32 位有符號)。 PHP 不支援無符號整數。 Integer值的字長可以用常數PHP_INT_SIZE來表示,自 PHP 4.4.0 和 PHP 5.0.5後,最大值可以用常數PHP_INT_MAX來表示。
輸出下32位元中PHP_INT_SIZE:4,PHP_INT_MAX:2147483647
輸出下64位元中PHP_INT_SIZE:8,PHP_INT_MAX:9223372036854775807


php計算一個字串的32位元CRC的函數crc32()

CRC32,很容易衝突啊該如何處理

#########PHP中crc32函數怎麼用來校驗資料##########

以上是php之crc32踩坑解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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