2017-01-16 158 views
-1

我在做一個需要隨機生成哈希數字的項目。在Arduino中生成由數字和字母組成的字符串哈希

該代碼必須按如下方式工作。

隨機函數產生一個隨機數,這些數字與一個字符串連接,然後生成該字符串的哈希,即每次生成一個數字時,該數字的哈希也生成,這必須循環。爲了生成哈希,我使用了一個名爲SpritzCipher的庫。

此代碼的問題在於,它生成單詞「隨機」的散列,而不是使用String(salt)串聯的哈希值。

這裏是我做的代碼:

#include <SpritzCipher.h> 

String salt = "fkllrnjnfd"; 
int randNumber; 
String valorConcat; 

void randomico() { 
    //Serial.begin(9600); 
    randomSeed(analogRead(0)); // Starts the list of random values 

    randNumber = random(100); // Draw a number from 0 to 99 

    valorConcat = String(randNumber) + salt; 

    //Serial.println(valorConcat); // Sends the value of randNumber to the serial 
    delay(500); // espera 500 ms 
} 


/* Data to input */ 

const byte testData[12] = {randomico}; 

/* Test vectors */ 
/* Data = 'testData' hash test vectors */ 
const byte testVector[32] = 
{ 0xff, 0x8c, 0xf2, 0x68, 0x09, 0x4c, 0x87, 0xb9, 
    0x5f, 0x74, 0xce, 0x6f, 0xee, 0x9d, 0x30, 0x03, 
    0xa5, 0xf9, 0xfe, 0x69, 0x44, 0x65, 0x3c, 0xd5, 
    0x0e, 0x66, 0xbf, 0x18, 0x9c, 0x63, 0xf6, 0x99 
}; 


void testFunc(const byte ExpectedOutput[32], const byte *data, byte dataLen) 
{ 
    byte hashLen = 32; /* 256-bit */ 
    byte digest[hashLen]; /* Output buffer */ 
    byte digest_2[hashLen]; /* Output buffer for chunk by chunk API */ 
    spritz_ctx hash_ctx; /* the CTX for chunk by chunk API */ 
    unsigned int i; 

    /* Print input */ 
    for (i = 0; i < dataLen; i++) { 
    Serial.write(data[i]); 
    } 
    Serial.println(); 

    spritz_hash_setup(&hash_ctx); 
    /* For easy test: code add a byte each time */ 
    for (i = 0; i < dataLen; i++) { 
    spritz_hash_update(&hash_ctx, data + i, 1); 
    } 
    spritz_hash_final(&hash_ctx, digest_2, hashLen); 

    spritz_hash(digest, hashLen, data, dataLen); 

    for (i = 0; i < sizeof(digest); i++) { 
    if (digest[i] < 0x10) { /* To print "0F" not "F" */ 
     Serial.write('0'); 
    } 
    Serial.print(digest[i], HEX); 
    } 

    /* Check the output */ 
    if (spritz_compare(digest, ExpectedOutput, sizeof(digest)) || spritz_compare(digest_2, ExpectedOutput, sizeof(digest_2))) { 
    /* If the output is wrong "Alert" */ 
    digitalWrite(LED_BUILTIN, HIGH); /* Turn pin LED_BUILTIN On (Most boards have this LED connected to digital pin 13) */ 
    Serial.println("\n** WARNING: Output != Test_Vector **"); 
    } 
    Serial.println(); 
} 

void setup() { 
    /* Initialize serial and wait for port to open */ 
    Serial.begin(9600); 
    while (!Serial) { 
    ; /* Wait for serial port to connect. Needed for Leonardo only */ 
    } 

    /* initialize digital pin LED_BUILTIN (Most boards have this LED connected to digital pin 13) as an output */ 
    pinMode(LED_BUILTIN, OUTPUT); 
    digitalWrite(LED_BUILTIN, LOW); 
} 

void loop() { 
    Serial.println("[Spritz spritz_hash*() test]\n"); 


    /* Data: arcfour */ 
    testFunc(testVector, testData, sizeof(testData)); 

    delay(5000); /* Wait 5s */ 
    Serial.println(); 
} 
+1

您散列'testData',但你連接字符串爲'valorConcat'。 'const byte testData [12] = {randomico};'沒有意義。你只是將它初始化爲'randomico'函數的地址。編譯器應該給你一個警告。 –

+1

另外你怎麼知道,你實際上哈希字符串'「隨機」'?你的代碼不會打印任何這樣的字符串。而你的'testVector'是字符串'「的散列,''arcfour」',並且不會匹配你的隨機鹹味字符串的任何散列。即使你將'arcfour'放入'testData','testVector'也不會匹配,因爲字符串'「arcfour \ 0 \ 0 \ 0 \ 0 \ 0」'將被散列。你應該使用'strlen'而不是'sizeof'。 –

+0

如何使用此算法來生成由「void random()」生成的String的哈希?你會知道如何做到這一點 –

回答

0

很多您的散列代碼只是和示例的散列字節數組,並將其與已知的散列的兩種不同的選擇。

由於您只需要計算哈希,您只需要撥打spritz_hash即可。

至於字符串的生成,更有效的方法是使用低級別的C++函數,因爲String對象使用動態內存分配,而使用can cause memory problems

#include <SpritzCipher.h> 

#define hex_char(n) ((n) < 10 ? '0' + (n) : 'A' + ((n)-10)) 

const char salt[] = "fkllrnjnfd"; 
char string[13] = ""; 
byte hash[32]; // byte hash 
char hash_string[65]; // hex string hash 

void randomico(char *string) 
{ 
    int randNumber = random(100); // Draw a number from 0 to 99 
    itoa(randNumber, string, 10); // convert int into char array 
    strcat(string, salt); // concatenate salt 
} 

void bytes_to_hexstr(char *string, byte *bytes, int size) 
{ 
    for (int i = 0; i < size; i++) 
    { 
     string[i*2] = bytes[i] < 16 ? '0' : hex_char((bytes[i] >> 4) & 0xF); 
     string[i*2+1] = hex_char(bytes[i] & 0xF); 
    } 
    string[size*2] = 0; 
} 

void setup() 
{ 
    Serial.begin(115200); 
    while (!Serial); 

    randomSeed(analogRead(0)); // Starts the list of random values 
} 

void loop() 
{ 
    randomico(string); // generate random salted string into 'string' variable 
    spritz_hash(hash, 32, (byte*)string, strlen(string)); // hash 'string' into 'hash' variable (hash only the character inside the string not the full char array) 
    bytes_to_hexstr(hash_string, hash, 32); // convert byte hash into printable hex string 

    // print out string and hash 
    Serial.print(string); 
    Serial.print(" -> "); 
    Serial.println(hash_string); 

    delay(1000); 
} 

但如果你真的想用String你能做到這樣:

String str = String(random(100))+salt; 
spritz_hash(hash, 32, (byte*)str.c_str(), str.length()); 
+0

首先,感謝您的幫助。 我只是不明白爲什麼它不打印字符串。 –

+0

你是什麼意思,它不打印字符串?你也得到垃圾嗎?我不知道爲什麼我的代碼在我發佈時工作,但'string'變量太小,無法保存2個字節的數字和10個字節的鹽加上空字符的1個字節(12應該至少爲13 )。現在它的工作原理應該如此。 –

+0

謝謝你的幫助。 隨着更改你仍然沒有正確打印,我做了一個改變(char hash_string [66];),你已經放置了65. 現在你正在做我想做的。 –

相關問題