C#实现HMACSHA256加密算法

C#实现HMACSHA256加密算法

在使用MQTT连接华为云时,发现通过密钥方式连接用了HMACSHA256加密算法,而在单片机中实现该算法还是有点困难,毕竟在单片机上运行内存有限,在项目中,我是使用了C#做一个配置软件,通过配置软件来实现它的加密,而单片机只管通过MQTT连接。

首先介绍一下什么是HMAC

HMAC是一种使用单向散列函数来构造消息认证码的方法,其中HMAC中的H就是Hash的意思。
HMAC中所使用的单向散列函数并不仅限于一种,任何高强度的单向散列函数都可以被用于HMAC,如果将来设计出的新的单向散列函数,也同样可以使用。
使用SHA-1、SHA-224、SHA-256、SHA-384、SHA-512所构造的HMAC,分别称为HMAC-SHA1、HMAC-SHA-224、HMAC-SHA-384、HMAC-SHA-512。
算法的描述
在HMAC的定义中用到一个密码散列函数H和一个密钥K。假设H是一个能够对明文进行分组循环压缩的散列函数,B为散列函数的明文分组长度(byte),在上述的散列函数中B=64,L为散列函数的输出长度(byte),MD5中L=16,SHA-1中L=20。认证密钥K可以为任意长度,一般密钥长度应大于明文分组的长度,将密钥的第一次散列值作为HMAC真正使用的密钥,密钥的最小推荐长度为Lbytes。
再定义两个不同的固定字符串ipad和opad如下(“i”和“o”表示内部和外部):
ipad=一个字节(byte)的0x36重复B次;
opad=一个字节(byte)的0x5C重复B次。
若以“text”作为要计算HMAC的明文,则作如下操作:
H(K XOR opad,H(K XOR ipad,text))
也就是说,操作步骤如下:
(1)在密钥K后面填充0,使其成为长度为Bbyte的字符串;如:K是20bytes的字符串,B=64,则要填充44个字节的0x00。
(2)用第一步得到的Bbyte的字符串与ipad作XOR(按位异或);
(3)将数据流text附加到第(2)步产生的Bbyte字符串后面;
(4)对第(3)产生的数据流用散列函数H计算消息摘要;
(5)用第一步得到的Bbyte的字符串与opad作XOR(按位异或);
(6)将第(4)生成的消息摘要附加到第(5)步的Bbyte字符串之后;
(7)对第(6)产生的数据流用散列函数H计算消息摘要,作为输出 。

C#具体实现函数

        private string HmacSHA256(string secret, string signKey)
        {
            string signRet = string.Empty;
            using (HMACSHA256 mac = new HMACSHA256(Encoding.UTF8.GetBytes(signKey)))
            {
                byte[] hash = mac.ComputeHash(Encoding.UTF8.GetBytes(secret));
                signRet = Convert.ToBase64String(hash);
                // signRet = ToHexString(hash); 
            }
            return signRet;
        }

如果需要输出16进制,则调用

signRet = ToHexString(hash); 

在华为云加密中,输入参数为 密钥(deviceSecret)和时间戳(dataForm)

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
HmacSha256是一种基于SHA-256(Secure Hash Algorithm 256-bit)算法的消息鉴别码算法。在C语言中,可以使用OpenSSL库来实现HmacSha256加密算法。 首先,我们需要包含OpenSSL库的头文件和链接静态库文件。在C代码中,可以使用以下指令进行包含: #include <openssl/hmac.h> ``` gcc -o example example.c -lcrypto ``` 接下来,我们可以定义一个函数来实现HmacSha256加密算法: ``` #include <stdio.h> #include <string.h> #include <openssl/hmac.h> void hmac_sha256(const unsigned char *key, int key_len, const unsigned char *data, int data_len, unsigned char *digest) { HMAC_CTX *hmac_ctx; unsigned int sha256_len; hmac_ctx = HMAC_CTX_new(); HMAC_Init_ex(hmac_ctx, key, key_len, EVP_sha256(), NULL); HMAC_Update(hmac_ctx, data, data_len); HMAC_Final(hmac_ctx, digest, &sha256_len); HMAC_CTX_free(hmac_ctx); } int main() { unsigned char key[] = "secret_key"; unsigned char data[] = "message"; int key_len = strlen(key); int data_len = strlen(data); unsigned char digest[EVP_MAX_MD_SIZE]; hmac_sha256(key, key_len, data, data_len, digest); printf("HMAC-SHA256 digest: "); for (int i = 0; i < SHA256_DIGEST_LENGTH; i++) { printf("%02x", digest[i]); } printf("\n"); return 0; } ``` 在main函数中,我们使用一个密钥key和一个消息data来进行HmacSha256加密,结果存储在digest数组中。输出结果是一个64字节的摘要。 编译并运行这段代码,将会输出HMAC-SHA256摘要结果。 这就是在C语言中实现HmacSha256加密算法的简单示例。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值