我只是想知道,是有一個原因一些圖書館(無論是任何語言)使用迭代散列使得散列數據以十六進制編碼,再改頭換面換湯不換藥實際的二進制輸出,而不是?迭代散列
Q
迭代散列
3
A
回答
0
閱讀此頁,特別是部分約迭代散列和雙散列結束http://hungred.com/useful-information/enhance-security-hash-function-web-development/
我猜TL;將部分博士版本將在年底的一句話說:「因此,儘量避免重複散列,然後進行迭代散列,而且,用相同的算法散列兩次被認爲是不理想的。「
-1
這樣做是爲了引入一個額外的步驟,以防止該散列可能開始,如果它被迭代直接施加到相同的散列的結果以產生相同或相似的輸出。這個額外的步驟與哈希實現無關,並且本身充當另一個不會受傷的重新哈希階段。這種預防措施對於可靠的哈希來說不是必需的 - 但是,如果某些哈希算法存在未知缺陷,您將永遠無法預知。
相關問題
- 1. 迭代散列打印散列?
- 2. 迭代散列數組
- 3. 迭代數組/散列圖
- 4. 通過散列表列表迭代
- 5. 迭代散列/陣列組合
- 6. 如何在存在空白散列時迭代散列數組?
- 7. 如何迭代F#中的散列表?
- 8. 迭代通過數據數組/散列
- 9. 如何迭代這個散列?
- 10. 如何在Ruby中迭代散列?
- 11. 如何迭代數組的散列
- 12. 迭代通過哈希散列內
- 13. 特定範圍的迭代散列
- 14. 在傀儡中迭代yaml散列
- 15. 紅寶石通過散列迭代
- 16. 通過散列集迭代的問題
- 17. perl中的散列鍵迭代
- 18. 在數組中迭代散列
- 19. 如何使用coffeescript迭代JSON散列
- 20. 通過散列數組迭代
- 21. 的Javascript迭代對散列錯誤
- 22. 迭代嵌套(多級)散列映射
- 23. 通過散列圖進行迭代
- 24. 基於插入順序迭代散列?
- 25. ruby在迭代中打印散列值
- 26. 在散列中的散列中的散列中對數組中的散列進行迭代?
- 27. 循環中的散列數組,每次迭代期間重寫散列值
- 28. 迭代散列的數組元素時展平散列。紅寶石
- 29. 迭代通過散列和輸出密鑰的陣列,價值
- 30. 通過散列迭代輸出一個無序列表
等一下,你是說哈希算法不返回原始輸出,返回某種「散列」輸出?我認爲這不是事實。 AFAIK,大多數庫會將二進制數據轉換爲十六進制(編碼),或者單獨返回二進制數據。我沒有理由在這裏使用十六進制(基數爲16)而非二進制(基數爲2)。 – Tower 2009-12-28 13:35:34
不,如果你有十六進制輸出,你可以將它轉換爲原始的,反之亦然。事實上,散列的輸出在重新散列之前會以某種方式進行轉換,可以提高安全性。關鍵不在於轉換本身,關鍵在於它在應用相同散列之前完成。 – sharptooth 2009-12-28 14:11:12
當我想到這一遍又一遍,我看不到的方式映射0-255字節爲0-15個字節(而不是實際的字節,只是數量)和老調重彈它可以提高安全性如何。據我所知,它應該是相反的。與散列實際輸出相比,我們會通過再次對壓縮輸出進行散列來丟失熵。你能提供一些有關這方面的事實嗎?或者它只是在重新調整之前壓縮數據提高安全性的一種感覺? – Tower 2009-12-28 14:43:56