私が維持する必要があるコードには、Oauth 署名をねじ込むビットがあります。問題を HMAC-SHA1 ダイジェスト計算に絞り込みました。それを行うこのコードがあります:
char key[256]="", base[1024]="";
char hmacsha1[1024]="", hmac_base64[1024]="";
unsigned int hmacsha1_len;
HMAC(EVP_sha1(), key, strlen(key), (unsigned char *)data, strlen(data), (unsigned char *)hmacsha1, &hmacsha1_len);
gBase64CRInclude = FALSE;
BPos = 0;
XPos = 0;
SPos = 0;
for (i=0;i<hmacsha1_len;i++) {
ch = hmacsha1[i];
BBuf[BPos++] = ch;
if (BPos == 3) {
encodebase64Mem(hmac_base64, &SPos);
BBuf[0]=BBuf[1]=BBuf[2]=BBuf[3] = 0;
}
}
encodebase64Mem(hmac_base64, &SPos);
hmac_base64[SPos] = 0;
printf("HMAC-SHA1: %s\n", hmac_base64);
encodebase64Mem()
他の文字列は正しくエンコードされているため、問題ないようです。同様の例を見てきましたが、ダイジェストが正しく計算されない理由をまだ理解できません。助けてくれてありがとう、ありがとう!