SHA1 HMAC是一个带Arduino的字节数组

时间:2012-01-07 07:46:17

标签: arduino hmacsha1

如何在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>

有没有人知道另一种方式?

2 个答案:

答案 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