gpt4 book ai didi

将 sha1 摘要的一部分与 C 中的十六进制字符串进行比较

转载 作者:太空宇宙 更新时间:2023-11-04 06:09:06 25 4
gpt4 key购买 nike

我有一个字符串,我会像这样计算一个 sha1 摘要:

SHA1(sn, snLength, sha1Bin);

如果我是正确的,这会产生一个 20 字节的字符(带有二进制数据)。我想将这个 char 的最后 3 个字节与另一个 char 进行比较。此字符包含字符串“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 的新手,不理解它:-(

最佳答案

换一种方式更容易——将二进制数据转换为十六进制字符串进行比较:

char suffix[7];
sprintf(suffix, "%02x%02x%02x", sha1Bin[17], sha1Bin[18], sha1Bin[19]);
return stricmp(suffix, theVarWithHexValues) == 0;

即使您更喜欢转换为二进制,sscanf(...%2x...) 也比手动解析十六进制数要好。

关于将 sha1 摘要的一部分与 C 中的十六进制字符串进行比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4381694/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com