HASH和HMAC(8):HMAC算法原理

HMAC是密钥相关的哈希运算消息认证码(Hash-based Message Authentication Code)的缩写,在1997发布的RFC2104中被公布。它可以与任何迭代HASH函数(SHA1/SHA2)捆绑使用。

协议标准:RFC 2104: HMAC: Keyed-Hashing for Message Authentication

HMAC处理流程如下图所示:

1. 密钥处理:

当K的长度不大于Hash Block Size时,在K的尾部填充0,直到长度为Hask Block Size。

当K的长度大于Hash Block Size时,先做K做一次Hash。

2. 第1次Hash处理: Hash(ipad ⊕ K' || M) 

3. 第2次Hash处理: Hash((opad ⊕ K') || Hash(ipad ⊕ K' || M))

其中:

ipad为常量0x36...36,长度为Hash Block Size;

opad为常量0x5c...5c,长度为Hash Block Size;

K'为密钥处理后的密钥;

M为输入消息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值