組み込みプロジェクトで使用するために私自身のHMAC-SHA256を実装する必要があります。私はそれを動作させるのに問題があります。私も擬似コードを取得することはできません、手で計算された、私は間違って何かをしていることを知っている!HMACの実装 - 擬似コード
私のpseduoコードの計算。
key = 0x6d796b6579000000000000000000000000000000000000000000000000000000
o_key_pad = 0x31253739255c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c
:ウィキペディア
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
で図に続いて、私は、キー= "にmykey" とメッセージ= "HelloWorldの" のためのバイ手計算は、私は、次の取得を行うとi_key_pad = 0x5b4f5d534f363636363636363636363636363636363636363636363636363636
hash(i_key_pad ∥ message) = 6fb2e91de7b8b5ec6283846ff7245cd6eb4a4fd26056b529bd42d99fcf3314d2
と0d76a16089f85cd2169bb64b6f2c818e6a404a218896483fcd97fee5cce185ae