Adler-32 雜湊碼計算器
已發佈: 2025年2月17日 下午6:03:14 [UTC]
雜湊碼計算器使用 Adler-32 雜湊函數根據文字輸入或檔案上傳計算雜湊碼。該頁面是由英語機器翻譯而來的,以便盡可能多的人可以訪問。不幸的是,機器翻譯還不是一項完善的技術,因此可能會出現錯誤。如果您願意,可以在這裡查看原始英文版本:
Adler-32 Hash Code Calculator
Adler-32 Hash Code Calculator
Adler-32雜湊函數是一種簡單、快速且常用於資料完整性驗證的校驗和演算法。它由 Mark Adler 設計,常用於 zlib 等應用程式中的資料壓縮。與加密雜湊函數(如 SHA-256)不同,Adler-32 不是為安全性而設計的,而是為了快速錯誤檢查。它計算 32 位元(4 位元組)的校驗和,通常表示為 8 個十六進位字元。
完全披露:我沒有寫此頁面上使用的哈希函數的具體實現。它是 PHP 程式語言中包含的標準函數。為了方便起見,我僅製作了 Web 介面以便在此公開發布。
關於 Adler-32 哈希演算法
我不是數學家,但我會嘗試用日常類比來解釋這個雜湊函數,希望我的非數學家同事能夠理解。與許多加密雜湊函數不同,Adler32 是一個非常簡單的校驗和函數,所以這應該不會太糟糕;-)
想像一下,你有一袋帶有數字的小方塊,每個方塊代表一個字母或部分資料。例如,單字“Hi”有兩個方磚:一個代表“H”,一個代表“i”。
現在,我們要用這些圖塊做兩件簡單的事:
步驟 1:將它們加起來(總和 A)
- 從數字 1 開始(只是作為規則)。
- 將每塊磁磚的數字加到總數中。
第 2 步:計算所有總和(總和 B)
- 每次將新方塊的數字加到總和 A 中時,也會將總和 A 的新值加到總和 B 中。
- 這就像堆疊硬幣:在頂部添加一枚硬幣(總和 A),然後寫下新的總堆疊高度(總和 B)。
最後,將兩個總數合併在一起得到一個大數字。那個大數字就是 Adler-32 校驗和。