1

ハードコードされた文字列のハッシュ値を計算すると、正しい値が得られました。

unsigned char digest[MD5_DIGEST_LENGTH];
char string[] = "fnamelname";
MD5((unsigned char*)&string, strlen(string), (unsigned char*)&digest);
char mdString[33];

for(int i = 0; i < 16; i++)
   sprintf(&mdString[i*2], "%02x", (unsigned int)digest[i]);

printf("fullName: %s\n", string);
printf("md5 digest: %s\n", mdString);

準備された文字列のハッシュ値を計算すると、正しくない/変更されたハッシュ値が得られました。

char* fname = "fname";
char* lname = "lname";
char* fullname = new char[strlen(fname) + strlen(lname) + 1];
strcpy(fullname, fname);
strcat(fullname, lname);

MD5((unsigned char*) &fullname, strlen(fullname), (unsigned char*) &digest);

char mdString1[33];

for (int i = 0; i < 16; i++)
sprintf(&mdString1[i * 2], "%02x", (unsigned int) digest[i]);

printf("fullname: %s\n", fullname);
printf("md5 digest: %s\n", mdString1);
4

1 に答える 1

2

ここでは、データへのポインターではなく、ポインターへのポインターを使用しています。

MD5((unsigned char*) &fullname, strlen(fullname), (unsigned char*) &digest);

そのはず:

MD5((unsigned char*) fullname, strlen(fullname), (unsigned char*) &digest);

最初の例では、配列へのポインターが最初の要素へのポインターと同じメモリ内の場所を指しているため (異なる型を持つ depsite)、たまたまうまくいきました。しかし、そこであっても、 を削除することが望ましいでしょう&

于 2013-08-25T13:47:28.760 に答える