У меня есть строка, для которой я вычисляю дайджест sha1 следующим образом:
SHA1(sn, snLength, sha1Bin);
Если я прав, это приводит к 20-байтовому символу (с двоичными данными).Я хочу сравнить последние 3 байта этого символа с другим символом.Этот символ содержит строку "6451E6".64, 51 и E6 - шестнадцатеричные значения.Как преобразовать «6451E6», чтобы я мог сравнить его с помощью:
if(memcmp(&sha1Bin[(20 - 3)], theVarWithHexValues, 3) == 0)
{
}
У меня есть эта функция:
/*
* convert hexadecimal ssid string to binary
* return 0 on error or binary length of string
*
*/
u32 str2ssid(u8 ssid[],u8 *str) {
u8 *p,*q = ssid;
u32 len = strlen(str);
if( (len % 2) || (len > MAX_SSID_OCTETS) )
return(0);
for(p = str;(*p = toupper(*p)) && (strchr(hexTable,*p)) != 0;) {
if(--len % 2) {
*q = ((u8*)strchr(hexTable,*p++) - hexTable);
*q <<= 4;
} else {
*q++ |= ((u8*)strchr(hexTable,*p++) - hexTable);
}
}
return( (len) ? 0 : (p - str) / 2);
}
, которая делает то же самое, но я новичок в C ине понимаю: - (