算法SHA256变HMAC_SHA256


HMAC-SHA256算法,即使用SHA-256生成哈希值的HMAC算法。依据HMAC算法和SHA-256算法内容,可知HMAC-SHA256算法的明文分组长度B为512-bit,可通过任意长度密钥K(最小推荐长度为256-bit,一般应大于B),得出长度为256-bit散列值(摘要)。
定义为:
〖HMAC〗_SHA256 (k,m)=□SHA256(k’⊕opad∥SHA256(k’⊕ipad∥m))
其中:
SHA256 为SHA-256加密算法,其输出散列值长度256-bit;
∥ 拼接操作,将两个字符串拼接在一起;
B Hash函数明文分组长度,SHA-256算法中为512-bit;
k 为密钥(secret key);
m 为要认证的消息;
k’ 是从原始密钥 k 导出的另一个密钥(若 k 短于B,则向右填充零,直到与B相同;若k长于B,则对 k 进行一次SHA256散列计算)
opad 内部填充(0x5C5C5C…5C5C,512-bit常量);
ipad 外部填充(0x363636…3636,512-bit常量)

ProductSecret产品密钥:DMLMXLEBWOW6Voks                        16个字节
k'="DMLMXLEBWOW6Voks"                                
k'=0x444d4c4d584c4542574f5736566f6b73000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000                64字节     512bit

opad=0x5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C5C          64字节     512bit

ipad=0x36363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636            64字节     512bit

k’⊕ipad = 0x727b7a7b6e7a73746179610060595d45363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636
k’⊕opad = 0x181110110410191e0b130b6a0a33372f5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c

m="123456" = 0x313233343536

k’⊕ipad∥m =
0x727b7a7b6e7a73746179610060595d45363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636313233343536

SHA256(k’⊕ipad∥m)=0x3abace516abbbe349f053a7e8a2f14049762646f70ddb1bc2c6536a7544f7ae6

k’⊕opad∥SHA256(k’⊕ipad∥m)=
0x181110110410191e0b130b6a0a33372f5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c5c3abace516abbbe349f053a7e8a2f14049762646f70ddb1bc2c6536a7544f7ae6


SHA256(k’⊕opad∥SHA256(k’⊕ipad∥m))=

4161df4e1022c4e2c4306982877c898bf9f807c886e0e9b59171d26d54407271

4161df4e1022c4e2c4306982877c898bf9f807c886e0e9b59171d26d54407271     ==>在线工具生成HMAC计算、HMAC-MD5、HMAC-SHA1、HMAC-SHA256、HMAC-SHA512在线计算 - 1024Tools

  • 22
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: hmac_sha256_get是一个函数或方法,其作用是获得使用HMAC-SHA256算法对数据进行加密后的结果。 HMAC-SHA256是一种基于SHA-256哈希函数和密钥的消息认证码算法。它通过在数据上进行哈希运算,并利用密钥对哈希结果进行加密,以实现对数据的完整性和认证性的保护。 在使用hmac_sha256_get函数时,需要传入待加密的数据以及加密所需的密钥作为参数。该函数会将数据和密钥作为输入,经过HMAC-SHA256算法的处理,生成加密后的结果。 HMAC-SHA256算法的优势在于它具有较高的安全性和抗攻击能力。通过密钥的引入,在保证数据完整性的同时,还能有效防止数据被篡改或伪造。此外,HMAC-SHA256算法运算速度较快,可以在较短时间内完成加密计算。 使用hmac_sha256_get函数可以应用在许多领域,例如网络传输中的数据加密传输、数据存储的安全性保护、身份验证等等。通过使用HMAC-SHA256算法进行数据加密,能够确保数据的安全性和完整性,避免数据被非法篡改或伪造。 总而言之,hmac_sha256_get是一个用于获取使用HMAC-SHA256算法对数据进行加密的函数或方法,可以通过传入待加密的数据和密钥,获得加密后的结果。这有助于保护数据的完整性和认证性,并具有较高的安全性和抗攻击能力。 ### 回答2: hmac_sha256_get是一种基于SHA256哈希算法的消息签名校验方法。HMAC是“基于哈希的消息认证码”(Hash-based Message Authentication Code)的缩写,它采用哈希算法结合密钥生成一个固定长度的消息认证码,用于保证消息的完整性和真实性。 在hmac_sha256_get中,通过对消息和密钥进行处理,生成一个用于校验和鉴别消息的摘要。具体的生成过程包括以下几个步骤: 1. 初始化:准备一个密钥,并设置加密函数为SHA256。 2. 对消息进行处理:使用SHA256哈希算法对待签名的消息进行哈希,生成一个消息摘要。 3. 密钥处理:如果密钥长度大于哈希算法的块长度,将密钥进行哈希运算后再使用,如果密钥长度小于哈希算法的块长度,则在其后补0,以达到哈希算法所需的块长度。 4. 分块运算:将处理后的密钥与以下常数分别进行异或运算:0x36(00110110)与0x5C(01011100)。然后将第3步中处理后的密钥和第4步中的分块值进行拼接。 5. 再次哈希:使用SHA256哈希算法对第4步中拼接的值进行哈希,得到一个中间结果。 6. 最后一步:再次进行分块运算,将第3步中的处理后的密钥和第6步中的分块值进行拼接,然后使用SHA256哈希算法对拼接后的值进行哈希。 最后得到的哈希值就是hmac_sha256_get的结果,可以用于校验消息的完整性和真实性。只有通过相同的密钥和相同的消息进行计算才能得到相同的结果,一旦有任何的篡改或伪造,校验结果就会不一致。因此,hmac_sha256_get是一种安全可靠的消息验证机制。 ### 回答3: hmac_sha256_get是一种加密算法,用于生成消息认证码,保证消息的完整性和认证性。具体来说,对于输入的消息和密钥,hmac_sha256_get会使用SHA-256哈希算法对消息进行摘要处理,并结合密钥生成一个哈希值。 这个哈希值作为消息认证码,可以用于验证消息的完整性和真实性。在验证的过程中,接收方会使用相同的密钥和相同的算法对接收到的消息进行重新计算,然后将计算得到的哈希值与发送方提供的消息认证码进行比较。如果两者相同,则说明消息未被篡改过,同时也证明了消息的真实性。 hmac_sha256_get的安全性主要在于哈希算法的不可逆性和密钥的保密性。SHA-256算法是一种广泛应用的哈希算法,其具有较高的安全性和强大的抗碰撞能力,使得不可能通过已知的哈希值来推导出原始的消息内容。同时,密钥的保密性也是保证消息认证码的安全性的重要因素,只有知道密钥的人才能够生成正确的消息认证码。 总的来说,hmac_sha256_get是一种可靠的加密算法,被广泛应用于网络通信和信息安全领域,保证了消息的完整性、真实性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值