Chapter 18: One-Way Hash Functions Based on Schneier
Background M, message of arbitrary size Hash function H(M) returns a value h of m bits: h = H(M) Characteristics of H(M) –Easy to compute h –Hard to compute M given h –Hard to find another message, M’ such that H(M) = H(M’) Birthday attack –Find any two messages M and M’ such that H(M) = H(M’) To survive a birthday attack, most one-way hash functions produce 128-bit or larger hashes
Overview of One-way Hash Functions Built-on idea of compression function Divide a message into blocks Hash of block M i is h i = f(M i, h i-1 ) Hash of the last block is the hash of the entire message
MD5 Message digest version 5, an extension of MD4 Produces 128-bit hash Conjectured that it is computationally infeasible to produce two messages having the same message digest Intended for digital signature applications
Terminology and Notation "word“ –A 32-bit quantity, a group of four bytes with the low- order (least significant) byte given first “+” –Denotes addition of words, mod 2 32 X << s –Circular shifting (rotating) bits of X by s positions
MD5 Algorithm Description Message of b bits as m 0, m 1,... m b-1 Step 1. Append Padding Bits –A single “1” bit appended and then “0” bits are appended so that the length in bits of the padded message becomes congruent to 448 mod 512 –Padding is always performed, even if the length is already congruent to 448 mod 512 –In all at least one bit and at most 512 bits are appended
MD5 Algorithm Description (cont’d) Step 2. Append Length –Append a 64-bit representation of b to the padded message of the previous step –Resulting message has length, exactly multiple of 512 bits (16 words) –Let M[0... N-1] denote the words, where N is a multiple of 16 Step 3. Initialize MD Buffer –Initialize a four-word buffer (A, B, C, D) with low-order bytes first in each word A: B: 89 ab cd ef C: fe dc ba 98 D:
MD5 Algorithm Description (cont’d) Step 4. Process Message in 16-Word Blocks –Define four auxiliary functions as: F(X,Y,Z) = (X and Y) or (not(X) and Z) G(X,Y,Z) = (X and Z) or (Y and (not (Z)) H(X,Y,Z) = X xor Y xor Z I(X, Y, Z) = Y xor (X or (Not (Z)) where X, Y, and Z are 32-bit words –Use a 64-bit element table T[ ] constructed from the sine function. Let T[i] = integer part of * abs(sin(i)) where i is in radians
MD5 Algorithm Description (cont’d) –Do the following /* Process each 16-word block. */ For i = 0 to N/16-1 do /* Copy block i into X. */ For j = 0 to 15 do Set X[ j] to M[i*16+j]. end /* of loop on j */ /* Save A as AA, B as BB, C as CC, and D as DD. */ AA = A BB = B CC = C DD = D
MD5 Algorithm Description (cont’d) /* Round 1. */ /* Let [abcd k s i] denote the operation a = b + ((a + F(b,c,d) + X[k] + T[i]) <<< s). */ /* Do the following 16 operations. */ [ABCD 0 7 1] [DABC ] [CDAB ] [BCDA ] [ABCD 4 7 5] [DABC ] [CDAB ] [BCDA ] [ABCD 8 7 9] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] /* Round 2. */ /* Let [abcd k s i] denote the operation a = b + ((a + G(b,c,d) + X[k] + T[i]) <<< s). */ /* Do the following 16 operations. */ [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ]
MD5 Algorithm Description (cont’d) /* Round 3. */ /* Let [abcd k s t] denote the operation a = b + ((a + H(b,c,d) + X[k] + T[i]) <<< s). */ /* Do the following 16 operations. */ [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] /* Round 4. */ /* Let [abcd k s t] denote the operation a = b + ((a + I(b,c,d) + X[k] + T[i]) <<< s). */ /* Do the following 16 operations. */ [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ] [ABCD ] [DABC ] [CDAB ] [BCDA ]
MD5 Algorithm Description (cont’d) /* Then perform the following additions. (That is increment each of the four registers by the value it had before this block was started.) */ A = A + AA B = B + BB C = C + CC D = D + DD end /* of loop on i */ Step 5. Output –Output is (A, B, C, D) beginning with the lower-byte of A and end with the high-order byte of D
Security of MD5 Check these sites: 05/06/more_md5_collis.htmlhttp:// 05/06/more_md5_collis.html 05/06/more_md5_collis.htmlhttp:// 05/06/more_md5_collis.html md5/md5.htmlhttp://userpages.umbc.edu/~mabzug1/cs/ md5/md5.html
Secure Hash Algorithm (SHA-1) Message length < 2 64 bits Produces a 160-bit message digest NIST and NSA involved in designing the algorithm Computationally infeasible –to find a message which corresponds to a given message digest, or –to find two different messages which produce the same message digest
SHA-1 RFC Convention OPERATIONS ON WORDS Bitwise logical word operations X ^ Y = bitwise logical "and" of X and Y X \/ Y = bitwise logical "inclusive-or" of X and Y X XOR Y = bitwise logical "exclusive-or" of X and Y ~ X = bitwise logical "complement" of X. The operation X + Y is defined as follows: –words X and Y represent integers x and y, where 0 <= x < 2 32 and 0 <= y < 2 32 –For positive integers n and m, let n mod m be the remainder upon dividing n by m –Compute z = (x + y) mod Then 0 <= z < Convert z to a word, Z, and define Z = X + Y.
SHA-1 RFC Convention (cont’d) OPERATIONS ON WORDS Circular left shift operation S n (X), where X is a word and n is an integer with 0 <= n <= 32, is defined by S n (X) = (X > 32-n). In the above, X > n is obtained by discarding the right-most n bits of X and then padding the result with n zeroes on the left. Thus S n (X) is equivalent to a circular shift of X by n positions to the left.
SHA-1 Description Message Padding –make the total length of a padded message a multiple of 512 –Padding process is exactly same as in MD5 –The padded message will contain 16 * n words for some n > 0 –The padded message is regarded as a sequence of n blocks M1, M2,..., Mn, where each Mi contains 16 words and M1 contains the first characters (or bits) of the message
SHA-1 Description (cont’d) Functions Used –A sequence of logical functions f 0, f 1,..., f 79 is used –With B, C, D 32-bit inputs, f t (B,C,D) is defined as: f t (B,C,D) = (B AND C) OR ((NOT B) AND D) ( 0 <= t <= 19) f t (B,C,D) = B XOR C XOR D (20 <= t <= 39) f t (B,C,D) = (B AND C) OR (B AND D) OR (C AND D) (40 <= t <= 59) f t (B,C,D) = B XOR C XOR D (60 <= t <= 79).
SHA-1 Description (cont’d) Constants Used –A sequence of constant words K(0), K(1),..., K(79) –In hex these are given by K(t) = 5A ( 0 <= t <= 19) K(t) = 6ED9EBA1 (20 <= t <= 39) K(t) = 8F1BBCDC (40 <= t <= 59) K(t) = CA62C1D6 (60 <= t <= 79)
SHA-1 Description (cont’d) Computing –Computed using the final padded message –Uses two buffers, each consisting of five 32-bit words, and a sequence of eighty 32-bit words –The words of the first 5-word buffer are labeled A,B,C,D,E –The words of the second 5-word buffer are labeled H0, H1, H2, H3, H4. –The words of the 80-word sequence are labeled W0, W1,..., W79 –A single word buffer TEMP is also employed. –To generate the message digest, the 16-word blocks M1, M2,..., Mn are processed in order –The processing of each Mi involves 80 steps
SHA-1 Description (cont’d) Before processing any blocks, the {Hi} are initialized as follows: in hex, H0 = H1 = EFCDAB89 H2 = 98BADCFE H3 = H4 = C3D2E1F0
SHA-1 Description (cont’d) Now M1, M2,..., Mn are processed. To process Mi, we proceed as follows: –Divide Mi into 16 words W 0, W 1,..., W 15, where W 0 is the left- most word. –For t = 16 to 79 let W t = S 1 (W t-3 XOR W t-8 XOR W t- 14 XOR W t-16 ). –Let A = H 0, B = H 1, C = H 2, D = H 3, E = H 4. –For t = 0 to 79 do TEMP = S 5 (A) + f t (B,C,D) + E + W t + K t ; E = D; D = C; C = S 30 (B); B = A; A = TEMP; –Let H 0 = H 0 + A, H 1 = H 1 + B, H 2 = H 2 + C, H 3 = H 3 + D, H 4 = H 4 + E.
SHA-1 Description (cont’d) After processing Mn, the message digest is the 160-bit string represented by the 5 words –H0 H1 H2 H3 H4.
Security of SHA-1 Check these sites – 2/sha1_broken.htmlhttp:// 2/sha1_broken.html – 6/ever_better_cry.htmlhttp:// 6/ever_better_cry.html –New hash algorithm: SHA2 published by NIST