Je dois implémenter mon propre HMAC-SHA256 pour l'utiliser dans un projet embarqué. J'ai du mal à le faire fonctionner. Je ne peux même pas obtenir le pseudo code, calculé à la main pour fonctionner, alors je sais que je fais quelque chose de mal!Implémentation HMAC - Pseudo code
Mes calculs de pseduoCode. En suivant le schéma wikipedia
1 function hmac (key, message)
2 if (length(key) > blocksize) then
3 // keys longer than blocksize are shortened
4 key = hash(key)
5 end if
6 if (length(key) < blocksize) then
7 // keys shorter than blocksize are zero-padded
8 key = key ∥ zeroes(blocksize - length(key))
9 end if
10
11 // Where blocksize is that of the underlying hash function
12 o_key_pad = [0x5c * blocksize] ⊕ key
13 i_key_pad = [0x36 * blocksize] ⊕ key // Where ⊕ is exclusive or (XOR)
14 // Where ∥ is concatenation
15 return hash(o_key_pad ∥ hash(i_key_pad ∥ message))
16 end function
Quand je fais de main calculs pour key = "MyKey" et message = "helloworld" Je reçois le texte suivant:
key = 0x6d796b6579000000000000000000000000000000000000000000000000000000
o_key_pad = 0x31253739255c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c
i_key_pad = 0x5b4f5d534f363636363636363636363636363636363636363636363636363636
hash(i_key_pad ∥ message) = 6fb2e91de7b8b5ec6283846ff7245cd6eb4a4fd26056b529bd42d99fcf3314d2
et le HMAC global de 0d76a16089f85cd2169bb64b6f2c818e6a404a218896483fcd97fee5cce185ae