如何在Arduino上HMAC一个字节数组?我找到了SHA1 HMAC的this library,但它似乎只用于字符串。
我在空终止的字节数组中传递了它的字节。这确实给了我正确的结果。但是对于包含零的字节数组不能很好地工作!
uint8_t hmacKey1[]={ 0x48, 0x65, 0x6c, 0x6c, 0x6f, 0x21, 0xde, 0xad, 0xbe, 0xef };
uint8_t time[]={ 0xb2, 0x00 };
Sha1.initHmac(hmacKey1, 10);
Sha1.print((char*)time);
要么我需要找到另一个库(crypto-arduino-library看起来很有希望,但不包括我正在做的任何示例),或者破解Cathedrow库以完成我正在做的事情。< / p>
有没有人知道另一种方式?
答案 0 :(得分:3)
添加我自己的方法似乎已经成功了:
void Sha1Class::writebytes(const uint8_t* data, int length) {
for (int i=0; i<length; i++)
{
write(data[i]);
}
}
答案 1 :(得分:1)
如果您不想更改sha1.cpp,您只需循环并打印每个字节,诀窍是使用Sha1.print((char) basestring[i]);
,如下所示:
#include <avr/pgmspace.h>
#include <sha1.h>
char key[] = "testKey";
uint8_t basestring[] = { 0x74, 0x65, 0x73, 0x74, 0x69, 0x6e, 0x67 }; // testing
void printHash(uint8_t* hash) {
for (int i=0; i<20; i++) {
Serial.print("0123456789abcdef"[hash[i]>>4]);
Serial.print("0123456789abcdef"[hash[i]&0xf]);
}
Serial.println();
}
void setup() {
Serial.begin(115200);
Serial.print("Input: ");
for (int i=0; i<sizeof(basestring); i++) {
Serial.print((char) basestring[i]);
}
Serial.println();
Serial.print("Key: ");
Serial.println(key);
Serial.print("Hmac-sha1 (hex): ");
Sha1.initHmac((uint8_t*)key, strlen(key));
for (int i=0; i<sizeof(basestring); i++) {
Sha1.print((char) basestring[i]);
}
uint8_t *hash;
hash = Sha1.resultHmac();
printHash(hash);
}
void loop() { }
<强>输出强>
Input: testing
Key: testKey
Hmac-sha1 (hex): 60d41271d43b875b791e2d54c34bf3f018a29763