【发布时间】:2013-01-09 22:41:10
【问题描述】:
有时您必须实现 C 代码和加密,所以我的 hmac256 或 sha2_hmac 实现的 C 代码实现存在问题:
unsigned char key[19] = { "abcdef" };
size_t keylen = 18;
unsigned char input[64] = {"123456789"};
size_t ilen = 63;
unsigned char output[32];
int is224 = 0;
sha2_hmac(key, keylen, input, ilen, output, is224);
char result[64] = {};
char result2[64] = {};
for(int j = 0; j < 32; j++) {
sprintf(result, "%X", output[j]);
strcat(result2, result);
}
但是当我将它与 C# 代码进行比较时,结果太短了。
【问题讨论】:
-
请贴出预期输出、实际输出和C#代码。
-
测验问题:如果
output[j]sprintf(result, "%X", output[j]); 会给出预期的结果吗?如果没有,可以对格式字符串进行什么更改来实现它? -
对不起不明白...结果太短了也太长了