青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0
什么是 Hash
Hash 的重要特性
Hash 函數的實現
主要的 Hash 算法
Hash 算法的安全問題
Hash 算法的應用
結 論
---------------

Hash, 一般翻譯做“散列”,也有直接音譯為"哈希"的,就是把任意長度的輸入(又叫做預映射, pre-image),通過散列算法,變換成固定長度的輸出,該輸出就是散列值。這種轉換是一種壓縮映射,也就是,散列值的空間通常遠小于輸入的空間,不 同的輸入可能會散列成相同的輸出,而不可能從散列值來唯一的確定輸入值。

數學表述為:h = H(M) ,其中H( )--單向散列函數,M--任意長度明文,h--固定長度散列值。

在信息安全領域中應用的

第 一當然是單向性(one-way),從預映射,能夠簡單迅速的得到散列值,而在計算上不可能構造一個預映射,使其散列結果等于某個特定的散列值,即構造相 應的M=H-1(h)不可行。這樣,散列值就能在統計上唯一的表征輸入值,因此,密碼學上的 Hash 又被稱為"消息摘要(message digest)",就是要求能方便的將"消息"進行"摘要",但在"摘要"中無法得到比"摘要"本身更多的關于"消息"的信息。

第 二是抗沖突性(collision-resistant),即在統計上無法產生2個散列值相同的預映射。給定M,計算上無法找到M ,滿足H(M)=H(M ) ,此謂弱抗沖突性;計算上也難以尋找一對任意的M和M ,使滿足H(M)=H(M ) ,此謂強抗沖突性。要求"強抗沖突性"主要是為了防范所謂"生日攻擊(birthday attack)",在一個10人的團體中,你能找到和你生日相同的人的概率是2.4%,而在同一團體中,有2人生日相同的概率是11.7%。類似的,當預 映射的空間很大的情況下,算法必須有足夠的強度來保證不能輕易找到"相同生日"的人。

第 三是映射分布均勻性和差分分布均勻性,散列結果中,為 0 的 bit 和為 1 的 bit ,其總數應該大致相等;輸入中一個 bit 的變化,散列結果中將有一半以上的 bit 改變,這又叫做"雪崩效應(avalanche effect)";要實現使散列結果中出現 1bit 的變化,則輸入中至少有一半以上的 bit 必須發生變化。其實質是必須使輸入中每一個 bit 的信息,盡量均勻的反映到輸出的每一個 bit 上去;輸出中的每一個 bit,都是輸入中盡可能多 bit 的信息一起作用的結果。

Damgard 和 Merkle 定義了所謂“壓縮函數(compression function)”,就是將一個固定長度輸入,變換成較短的固定長度的輸出,這對密碼學實踐上 Hash 函數的設計產生了很大的影響。Hash函數就是被設計為基于通過特定壓縮函數的不斷重復“壓縮”輸入的分組和前一次壓縮處理的結果的過程,直到整個消息都 被壓縮完畢,最后的輸出作為整個消息的散列值。盡管還缺乏嚴格的證明,但絕大多數業界的研究者都同意,如果壓縮函數是安全的,那么以上述形式散列任意長度 的消息也將是安全的。這就是所謂 Damgard/Merkle 結構:

在 下圖中,任意長度的消息被分拆成符合壓縮函數輸入要求的分組,最后一個分組可能需要在末尾添上特定的填充字節,這些分組將被順序處理,除了第一個消息分組 將與散列初始化值一起作為壓縮函數的輸入外,當前分組將和前一個分組的壓縮函數輸出一起被作為這一次壓縮的輸入,而其輸出又將被作為下一個分組壓縮函數輸 入的一部分,直到最后一個壓縮函數的輸出,將被作為整個消息散列的結果。

MD5 和 SHA1 可以說是目前應用最廣泛的Hash算法,而它們都是以 MD4 為基礎設計的。

1) MD4
MD4(RFC 1320)是 MIT 的 Ronald L. Rivest 在 1990 年設計的,MD 是 Message Digest 的縮寫。它適用在32位字長的處理器上用高速軟件實現--它是基于 32 位操作數的位操作來實現的。它的安全性不像RSA那樣基于數學假設,盡管 Den Boer、Bosselaers 和 Dobbertin 很快就用分析和差分成功的攻擊了它3輪變換中的 2 輪,證明了它并不像期望的那樣安全,但它的整個算法并沒有真正被破解過,Rivest 也很快進行了改進。

下面是一些MD4散列結果的例子:

MD4 ("") = 31d6cfe0d16ae931b73c59d7e0c089c0
MD4 ("a") = bde52cb31de33e46245e05fbdbd6fb24
MD4 ("abc") = a448017aaf21d8525fc10ae87aa6729d
MD4 ("message digest") = d9130a8164549fe818874806e1c7014b
MD4 ("abcdefghijklmnopqrstuvwxyz") = d79e1c308aa5bbcdeea8ed63df412da9
MD4 ("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789") = 043f8582f241db351ce627e153e7f0e4
MD4 ("12345678901234567890123456789012345678901234567890123456789012345678901234567890") = e33b4ddc9c38f2199c3e7b164fcc0536

2) MD5
MD5(RFC 1321)是 Rivest 于1991年對MD4的改進版本。它對輸入仍以512位分組,其輸出是4個32位字的級聯,與 MD4 相同。它較MD4所做的改進是:

1) 加入了第四輪
2) 每一步都有唯一的加法常數;
3) 第二輪中的G函數從((X ∧ Y) ∨ (X ∧ Z) ∨ (Y ∧ Z)) 變為 ((X ∧ Z) ∨ (Y ∧ ~Z))以減小其對稱性;
4) 每一步都加入了前一步的結果,以加快"雪崩效應";
5) 改變了第2輪和第3輪中訪問輸入子分組的順序,減小了形式的相似程度;
6) 近似優化了每輪的循環左移位移量,以期加快"雪崩效應",各輪的循環左移都不同。
盡管MD5比MD4來得復雜,并且速度較之要慢一點,但更安全,在抗分析和抗差分方面表現更好。

消 息首先被拆成若干個512位的分組,其中最后512位一個分組是“消息尾+填充字節(100…0)+64 位消息長度”,以確保對于不同長度的消息,該分組不相同。64位消息長度的限制導致了MD5安全的輸入長度必須小于264bit,因為大于64位的長度信 息將被忽略。而4個32位寄存器字初始化為A=0x01234567,B=0x89abcdef,C=0xfedcba98,D=0x76543210, 它們將始終參與運算并形成最終的散列結果。

接著各個512位消息分組以16個32位字的形式進入算法的主循環,512位消息分組的個數據決定了循環的次數。主循環有4輪,每輪分別用到了非線性函數

F(X, Y, Z) = (X ∧ Y) ∨ (~X ∧ Z)
G(X, Y, Z) = (X ∧ Z) ∨ (Y ∧ ~Z)
H(X, Y, Z) =X ⊕ Y ⊕ Z
I(X, Y, Z) = X ⊕ (Y ∨ ~Z)
這 4輪變換是對進入主循環的512位消息分組的16個32位字分別進行如下操作:將A、B、C、D的副本a、b、c、d中的3個經F、G、H、I運算后的結 果與第4個相加,再加上32位字和一個32位字的加法常數,并將所得之值循環左移若干位,最后將所得結果加上a、b、c、d之一,并回送至ABCD,由此 完成一次循環。

所用的加法常數由這樣一張表T[i]來定義,其中i為1…64,T[i]是i的正弦絕對值之4294967296次方的整數部分,這樣做是為了通過正弦函數和冪函數來進一步消除變換中的線性性。

當所有512位分組都運算完畢后,ABCD的級聯將被輸出為MD5散列的結果。下面是一些MD5散列結果的例子:

MD5 ("") = d41d8cd98f00b204e9800998ecf8427e
MD5 ("a") = 0cc175b9c0f1b6a831c399e269772661
MD5 ("abc") = 900150983cd24fb0d6963f7d28e17f72
MD5 ("message digest") = f96b697d7cb7938d525a2f31aaf161d0
MD5 ("abcdefghijklmnopqrstuvwxyz") = c3fcd3d76192e4007dfb496cca67e13b
MD5 ("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789") = d174ab98d277d9f5a5611c2c9f419d9f
MD5 ("12345678901234567890123456789012345678901234567890123456789012345678901234567890") = 57edf4a22be3c955ac49da2e2107b67a
參考相應RFC文檔可以得到MD4、MD5算法的詳細描述和算法的C源代碼。

3) SHA1 及其他
SHA1 是由NIST NSA設計為同DSA一起使用的,訪問http://www.itl.nist.gov/fipspubs可以得到它的詳細規范 --[/url]"FIPS PUB 180-1 SECURE HASH STANDARD"。它對長度小于264的輸入,產生長度為160bit的散列值,因此抗窮舉(brute-force)性更好。SHA-1 設計時基于和MD4相同原理,并且模仿了該算法。因為它將產生160bit的散列值,因此它有5個參與運算的32位寄存器字,消息分組和填充方式與MD5 相同,主循環也同樣是4輪,但每輪進行20次操作,非線性運算、移位和加法運算也與MD5類似,但非線性函數、加法常數和循環左移操作的設計有一些區別, 可以參考上面提到的規范來了解這些細節。下面是一些SHA1散列結果的例子:

SHA1 ("abc") = a9993e36 4706816a ba3e2571 7850c26c 9cd0d89d
SHA1 ("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq") = 84983e44 1c3bd26e baae4aa1 f95129e5 e54670f1
其他一些知名的Hash算法還有MD2、N-Hash、RIPE-MD、HAVAL等等。上面提到的這些都屬于"純"Hash算法。還有另2類Hash算法, 一類就是基于對稱分組算法的單向散列算法,典型的例子是基于DES的所謂Davies-Meyer算法,另外還有經IDEA改進的Davies- Meyer算法,它們兩者目前都被認為是安全的算法。另一類是基于模運算/離散對數的,也就是基于公開密鑰算法的,但因為其運算開銷太大,而缺乏很好的應 用前景。

沒有通過分析和差分攻擊考驗的算法,大多都已經夭折在實驗室里了,因此,如果目前流行的Hash算法能 完全符合密碼學意義上的單向性和抗沖突性,就保證了只有窮舉,才是破壞Hash運算安全特性的唯一方法。為了對抗弱抗沖突性,我們可能要窮舉個數和散列值 空間長度一樣大的輸入,即嘗試2^128或2^160個不同的輸入,目前一臺高檔個人電腦可能需要10^25年才能完成這一艱巨的工作,即使是最高端的并 行系統,這也不是在幾千年里的干得完的事。而因為"生日攻擊"有效的降低了需要窮舉的空間,將其降低為大約1.2*2^64或1.2*2^80,所以,強 抗沖突性是決定Hash算法安全性的關鍵。

在NIST新的 Advanced Encryption Standard (AES)中,使用了長度為128、192、256bit 的密鑰,因此相應的設計了 SHA256、SHA384、SHA512,它們將提供更好的安全性。

Hash算法在信息安全方面的應用主要體現在以下的3個方面:

1) 文件校驗
我們比較熟悉的校驗算法有奇偶校驗和CRC校驗,這2種校驗并沒有抗數據篡改的能力,它們一定程度上能檢測并糾正數據傳輸中的信道誤碼,但卻不能防止對數據的惡意破壞。

MD5 Hash算法的"數字指紋"特性,使它成為目前應用最廣泛的一種文件完整性校驗和(Checksum)算法,不少Unix系統有提供計算md5 checksum的命令。它常被用在下面的2種情況下:

第 一是文件傳送后的校驗,將得到的目標文件計算 md5 checksum,與源文件的md5 checksum 比對,由兩者 md5 checksum 的一致性,可以從統計上保證2個文件的每一個碼元也是完全相同的。這可以檢驗文件傳輸過程中是否出現錯誤,更重要的是可以保證文件在傳輸過程中未被惡意篡 改。一個很典型的應用是ftp服務,用戶可以用來保證多次斷點續傳,特別是從鏡像站點下載的文件的正確性。

更 出色的解決方法是所謂的代碼簽名,文件的提供者在提供文件的同時,提供對文件Hash值用自己的代碼簽名密鑰進行數字簽名的值,及自己的代碼簽名證書。文 件的接受者不僅能驗證文件的完整性,還可以依據自己對證書簽發者和證書擁有者的信任程度,決定是否接受該文件。瀏覽器在下載運行插件和java小程序時, 使用的就是這樣的模式。

第二是用作保存二進制文件系統的數字指紋,以便檢 測文件系統是否未經允許的被修改。不少系統管理/系統安全軟件都提供這一文件系統完整性評估的功能,在系統初始安裝完畢后,建立對文件系統的基礎校驗和數 據庫,因為散列校驗和的長度很小,它們可以方便的被存放在容量很小的存儲介質上。此后,可以定期或根據需要,再次計算文件系統的校驗和,一旦發現與原來保 存的值有不匹配,說明該文件已經被非法修改,或者是被病毒感染,或者被木馬程序替代。TripWire就提供了一個此類應用的典型例子。

更 完美的方法是使用"MAC"。"MAC" 是一個與Hash密切相關的名詞,即信息鑒權碼(Message Authority Code)。它是與密鑰相關的Hash值,必須擁有該密鑰才能檢驗該Hash值。文件系統的數字指紋也許會被保存在不可信任的介質上,只對擁有該密鑰者提 供可鑒別性。并且在文件的數字指紋有可能需要被修改的情況下,只有密鑰的擁有者可以計算出新的散列值,而企圖破壞文件完整性者卻不能得逞。

2) 數字簽名
Hash 算法也是現代密碼體系中的一個重要組成部分。由于非對稱算法的運算速度較慢,所以在數字簽名協議中,單向散列函數扮演了一個重要的角色。

在這種簽名協議中,雙方必須事先協商好雙方都支持的Hash函數和簽名算法。

簽名方先對該數據文件進行計算其散列值,然后再對很短的散列值結果--如Md5是16個字節,SHA1是20字節,用非對稱算法進行數字簽名操作。對方在驗證簽名時,也是先對該數據文件進行計算其散列值,然后再用非對稱算法驗證數字簽名。

對 Hash 值,又稱"數字摘要"進行數字簽名,在統計上可以認為與對文件本身進行數字簽名是等效的。而且這樣的協議還有其他的優點:

首先,數據文件本身可以同它的散列值分開保存,簽名驗證也可以脫離數據文件本身的存在而進行。

再 者,有些情況下簽名密鑰可能與解密密鑰是同一個,也就是說,如果對一個數據文件簽名,與對其進行非對稱的解密操作是相同的操作,這是相當危險的,惡意的破 壞者可能將一個試圖騙你將其解密的文件,充當一個要求你簽名的文件發送給你。因此,在對任何數據文件進行數字簽名時,只有對其Hash值進行簽名才是安全 的。

3) 鑒權協議
如下的鑒權協議又被稱作"挑戰--認證模式:在傳輸信道是可被偵聽,但不可被篡改的情況下,這是一種簡單而安全的方法。

需 要鑒權的一方,向將被鑒權的一方發送隨機串(“挑戰”),被鑒權方將該隨機串和自己的鑒權口令字一起進行 Hash 運算后,返還鑒權方,鑒權方將收到的Hash值與在己端用該隨機串和對方的鑒權口令字進行 Hash 運算的結果相比較(“認證”),如相同,則可在統計上認為對方擁有該口令字,即通過鑒權。

POP3協議中就有這一應用的典型例子:

S: +OK POP3 server ready <1896.697170952@dbc.mtview.ca.us>
C: APOP mrose c4c9334bac560ecc979e58001b3e22fb
S: +OK maildrop has 1 message (369 octets)
在 上面的一段POP3協議會話中,雙方都共享的對稱密鑰(鑒權口令字)是tanstaaf,服務器發出的挑戰 是<1896.697170952@dbc.mtview.ca.us>,客戶端對挑戰的應答是 MD5("<1896.697170952@dbc.mtview.ca.us>tanstaaf") = c4c9334bac560ecc979e58001b3e22fb,這個正確的應答使其通過了認證。

散列算法長期以來一直在計算機科學中大量應用,隨著現代密碼學的發展,單向散列函數已經成為信息安全領域中一個重要的結構模塊,我們有理由深入研究其設計理論和應用方法。

from:
http://www.coood.com/postfile/2007-1-4/20071495110.shtml

posted on 2010-03-09 21:02 chatler 閱讀(490) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm
<2010年11月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜精品久久久99热福利| 激情久久一区| 国产欧美视频在线观看| 在线看片欧美| 亚洲欧美日韩国产中文在线| 另类图片国产| 亚洲欧美另类综合偷拍| 欧美福利一区| 韩国一区二区三区美女美女秀| 亚洲人成在线观看| 欧美一区午夜视频在线观看| 亚洲国产精品一区| 欧美亚洲综合久久| 亚洲人成绝费网站色www| 欧美在线播放视频| 国产精品免费观看在线| 日韩亚洲欧美精品| 美日韩精品免费观看视频| 亚洲视频视频在线| 欧美日韩国产精品| 亚洲久色影视| 亚洲国产mv| 免费欧美日韩| 影音先锋亚洲电影| 久久久久欧美精品| 欧美在线在线| 亚洲精品一区二区网址 | 欧美精品在线播放| 亚洲国产精品视频| 欧美成人午夜激情在线| 久久久欧美精品sm网站| 在线电影院国产精品| 亚洲精选大片| 欧美午夜在线| 亚洲欧美综合另类中字| 美女精品自拍一二三四| 最新国产成人在线观看| 亚洲一品av免费观看| 国产精品日韩高清| 久久国产精品72免费观看| 亚洲一区激情| 国产一区二区三区日韩| 久久人人爽人人| 欧美视频二区| 久久国产精品久久久久久久久久| 午夜在线精品| 永久久久久久| 亚洲欧美在线播放| 狠狠久久亚洲欧美专区| 亚洲视频在线一区| 99www免费人成精品| 久久九九免费| 一区二区精品国产| 亚洲欧美国产77777| 99视频在线观看一区三区| 夜色激情一区二区| 国产一区二区三区av电影| 99国产精品久久久久久久| 亚洲国产另类久久精品| 99在线精品免费视频九九视| 亚洲激情亚洲| 蜜臀av一级做a爰片久久| 久久夜色精品国产| 欧美日韩国产精品| 亚洲人成小说网站色在线| 亚洲国产三级网| 裸体一区二区| 亚洲国产精品123| 亚洲电影免费观看高清完整版在线观看| 亚洲免费在线| 久久精品夜夜夜夜久久| 欧美精品一线| 日韩视频精品在线| 黄色亚洲精品| 久久久精品日韩欧美| 久久在线91| 亚洲国产一区在线| 欧美国产极速在线| 9l国产精品久久久久麻豆| 亚洲专区免费| 欧美紧缚bdsm在线视频| 久久精品国产一区二区三区| 国产午夜精品久久久| 夜夜嗨一区二区三区| 亚洲一区免费观看| 国产日韩欧美一区在线| 欧美专区日韩专区| 欧美大胆人体视频| 这里只有精品视频| 国产欧美日韩综合一区在线播放| 久久国产精品久久久久久久久久| 亚洲一级片在线观看| 欧美精品v日韩精品v韩国精品v| 亚洲精品免费在线| 欧美亚洲日本国产| 亚洲国产精品传媒在线观看| 欧美日韩亚洲一区二| 亚洲青涩在线| 欧美一级免费视频| 亚洲黄色小视频| 国产精品久久久久aaaa九色| 日韩视频在线一区| 久久久精品久久久久| 亚洲破处大片| 国产欧美日韩在线播放| 欧美成人国产| 亚洲国产精品va在线看黑人动漫 | 国产精品日韩专区| 久久五月天婷婷| 狼人社综合社区| 亚洲午夜精品久久| 韩国v欧美v日本v亚洲v | 亚洲视频精品在线| 裸体一区二区三区| 亚洲欧美日韩国产中文在线| 亚洲国产精品一区二区www| 国产精品久久久久久av福利软件| 久热综合在线亚洲精品| 亚洲第一精品电影| 久久精品在线观看| 这里只有精品视频| 亚洲人成网站精品片在线观看 | 免费视频一区| 午夜电影亚洲| 在线亚洲欧美| 亚洲精品在线观看免费| 欧美激情视频一区二区三区在线播放| 亚洲国产乱码最新视频| 国产日韩欧美精品在线| 欧美日本簧片| 欧美激情一区二区三区不卡| 久久国产精品一区二区三区四区| 一本到高清视频免费精品| 亚洲第一网站| 欧美va亚洲va国产综合| 在线亚洲高清视频| 亚洲精品乱码久久久久久蜜桃麻豆| 狠狠色丁香久久综合频道| 国产麻豆午夜三级精品| 欧美.www| 欧美高清在线一区| 免费亚洲电影| 欧美成人精品在线视频| 欧美 亚欧 日韩视频在线| 久久午夜精品一区二区| 久久人人97超碰人人澡爱香蕉| 久久久久久久久久看片| 久久久精品国产99久久精品芒果| 久久精品人人做人人爽电影蜜月| 欧美一区二区在线免费播放| 亚洲国产欧美精品| 亚洲激情校园春色| 久久麻豆一区二区| 久热re这里精品视频在线6| 久久女同互慰一区二区三区| 久久一区二区三区超碰国产精品| 猛男gaygay欧美视频| 欧美黑人在线播放| 最新热久久免费视频| 一区二区三区www| 亚洲国产精品综合| 日韩亚洲欧美在线观看| 亚洲午夜久久久| 欧美中文字幕久久| 久久久天天操| 欧美激情成人在线| 国产精品青草久久| 国内成人精品一区| 国产乱码精品1区2区3区| 国内成人自拍视频| 日韩亚洲欧美精品| 欧美一区二区三区在线| 欧美jizzhd精品欧美巨大免费| 亚洲电影视频在线| 亚洲图片在线| 久久视频在线免费观看| 欧美日韩中文在线| 韩国女主播一区| 亚洲精品日日夜夜| 欧美在线观看视频一区二区| 欧美高清视频一区| 亚洲淫片在线视频| 欧美成人按摩| 国产日韩欧美精品在线| 99精品热视频只有精品10| 久久精品导航| 日韩视频免费| 老巨人导航500精品| 国产精品一区=区| 日韩写真视频在线观看| 久久精品一区二区三区不卡牛牛| 亚洲人成网站在线观看播放| 欧美在线观看一区二区| 欧美性久久久| 日韩亚洲欧美中文三级| 久久天天躁狠狠躁夜夜av| 亚洲视频图片小说| 欧美激情一区二区三区不卡| 好看的亚洲午夜视频在线| 午夜精品网站|