0

私は、ページから見つけたLPeterDeutschによるCのMD5実装とsourceforge.netのソースコードを使用しています。

mainファイルの関数のコードは、md5main.c次のように変更されています。

md5_byte_t *result = malloc ( 16 );  // Allocating 128 bits.
char data[] = "my name is aman";
md5_state_t state;  // This is a state object used by the MD5 library to do "stuff".
                    // Just treat it as a black box.
md5_init(&state);
md5_append(&state, (const md5_byte_t *)data, strlen(data));
md5_finish(&state, result);
print_bits(result, 128);

md5_append(&state, (const md5_byte_t *)data, strlen(data));
md5_finish(&state, result);
print_bits(result, 128);
//puts(usage);
return 0;

ビットの印刷機能は次のとおりです。

void print_bits ( void * data, int length )
{
    uint8_t *temp_data = (uint8_t *)data;
    int bytes = length>>3;
    printf ("[");
    int i;
    //printf("\nprinting bloom filter\n\n");
    for ( i=0; i<bytes; ++i )
    {
        int j;
        for ( j=sizeof(uint8_t)*8-1; j>=0; --j)
        {
            int l = temp_data[i]>>j & 1;
            printf( "%d", l);
        }
    }
    //printf("\n end printing bloom filter\n\n");
    printf ("]\n");
}

stdlib.hとコードを含める必要があります。

文字列に対して、my name is aman2回呼び出されると、2つの異なるハッシュ値が生成されます。それは私のシステムで以下を生成しました:

[01110000100000100110101111101101000011000100011100110111010100110010011100110011111100100111100100100011101011000111110011010101]
[11101001101110101111000010101100000000011011010110110011111001111010110111001011000001010000010111000010101111101101000010011000]

この奇妙な振る舞いの理由は何ですか?特定のキーに対して同じハッシュ値を生成することは想定されていませんでしたか?

4

1 に答える 1

4

md5_initへの最初の呼び出しの後で、もう一度呼び出す必要がありますmd5_finish

于 2012-06-21T13:24:58.887 に答える