當前位置:首頁 » 編程語言 » md5c語言計算文件

md5c語言計算文件

發布時間: 2022-02-24 13:53:54

A. 求c語言調用md5函數的函數,注意是直接輸入字元串就能獲得的,不要輸入文件名的那種

c語言標准庫沒有這個函數,隨便給你搜了一下別人的實現

/*md5.h*/
#ifndef MD5_H
#define MD5_H

typedef struct
{
unsigned int count[2];
unsigned int state[4];
unsigned char buffer[64];
}MD5_CTX;

#define F(x,y,z) ((x & y) | (~x & z))
#define G(x,y,z) ((x & z) | (y & ~z))
#define H(x,y,z) (x^y^z)
#define I(x,y,z) (y ^ (x | ~z))
#define ROTATE_LEFT(x,n) ((x << n) | (x >> (32-n)))
#define FF(a,b,c,d,x,s,ac) \
{ \
a += F(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
#define GG(a,b,c,d,x,s,ac) \
{ \
a += G(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
#define HH(a,b,c,d,x,s,ac) \
{ \
a += H(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
#define II(a,b,c,d,x,s,ac) \
{ \
a += I(b,c,d) + x + ac; \
a = ROTATE_LEFT(a,s); \
a += b; \
}
void MD5Init(MD5_CTX *context);
void MD5Update(MD5_CTX *context,unsigned char *input,unsigned int inputlen);
void MD5Final(MD5_CTX *context,unsigned char digest[16]);
void MD5Transform(unsigned int state[4],unsigned char block[64]);
void MD5Encode(unsigned char *output,unsigned int *input,unsigned int len);
void MD5Decode(unsigned int *output,unsigned char *input,unsigned int len);

#endif

/*md5.c*/
#include <memory.h>
#include "md5.h"

unsigned char PADDING[]={0x80,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};

void MD5Init(MD5_CTX *context)
{
context->count[0] = 0;
context->count[1] = 0;
context->state[0] = 0x67452301;
context->state[1] = 0xEFCDAB89;
context->state[2] = 0x98BADCFE;
context->state[3] = 0x10325476;
}
void MD5Update(MD5_CTX *context,unsigned char *input,unsigned int inputlen)
{
unsigned int i = 0,index = 0,partlen = 0;
index = (context->count[0] >> 3) & 0x3F;
partlen = 64 - index;
context->count[0] += inputlen << 3;
if(context->count[0] < (inputlen << 3))
context->count[1]++;
context->count[1] += inputlen >> 29;

if(inputlen >= partlen)
{
memcpy(&context->buffer[index],input,partlen);
MD5Transform(context->state,context->buffer);
for(i = partlen;i+64 <= inputlen;i+=64)
MD5Transform(context->state,&input[i]);
index = 0;
}
else
{
i = 0;
}
memcpy(&context->buffer[index],&input[i],inputlen-i);
}
void MD5Final(MD5_CTX *context,unsigned char digest[16])
{
unsigned int index = 0,padlen = 0;
unsigned char bits[8];
index = (context->count[0] >> 3) & 0x3F;
padlen = (index < 56)?(56-index):(120-index);
MD5Encode(bits,context->count,8);
MD5Update(context,PADDING,padlen);
MD5Update(context,bits,8);
MD5Encode(digest,context->state,16);
}
void MD5Encode(unsigned char *output,unsigned int *input,unsigned int len)
{
unsigned int i = 0,j = 0;
while(j < len)
{
output[j] = input[i] & 0xFF;
output[j+1] = (input[i] >> 8) & 0xFF;
output[j+2] = (input[i] >> 16) & 0xFF;
output[j+3] = (input[i] >> 24) & 0xFF;
i++;
j+=4;
}
}
void MD5Decode(unsigned int *output,unsigned char *input,unsigned int len)
{
unsigned int i = 0,j = 0;
while(j < len)
{
output[i] = (input[j]) |
(input[j+1] << 8) |
(input[j+2] << 16) |
(input[j+3] << 24);
i++;
j+=4;
}
}
void MD5Transform(unsigned int state[4],unsigned char block[64])
{
unsigned int a = state[0];
unsigned int b = state[1];
unsigned int c = state[2];
unsigned int d = state[3];
unsigned int x[64];
MD5Decode(x,block,64);
FF(a, b, c, d, x[ 0], 7, 0xd76aa478); /* 1 */
FF(d, a, b, c, x[ 1], 12, 0xe8c7b756); /* 2 */
FF(c, d, a, b, x[ 2], 17, 0x242070db); /* 3 */
FF(b, c, d, a, x[ 3], 22, 0xc1bdceee); /* 4 */
FF(a, b, c, d, x[ 4], 7, 0xf57c0faf); /* 5 */
FF(d, a, b, c, x[ 5], 12, 0x4787c62a); /* 6 */
FF(c, d, a, b, x[ 6], 17, 0xa8304613); /* 7 */
FF(b, c, d, a, x[ 7], 22, 0xfd469501); /* 8 */
FF(a, b, c, d, x[ 8], 7, 0x698098d8); /* 9 */
FF(d, a, b, c, x[ 9], 12, 0x8b44f7af); /* 10 */
FF(c, d, a, b, x[10], 17, 0xffff5bb1); /* 11 */
FF(b, c, d, a, x[11], 22, 0x895cd7be); /* 12 */
FF(a, b, c, d, x[12], 7, 0x6b901122); /* 13 */
FF(d, a, b, c, x[13], 12, 0xfd987193); /* 14 */
FF(c, d, a, b, x[14], 17, 0xa679438e); /* 15 */
FF(b, c, d, a, x[15], 22, 0x49b40821); /* 16 */

/* Round 2 */
GG(a, b, c, d, x[ 1], 5, 0xf61e2562); /* 17 */
GG(d, a, b, c, x[ 6], 9, 0xc040b340); /* 18 */
GG(c, d, a, b, x[11], 14, 0x265e5a51); /* 19 */
GG(b, c, d, a, x[ 0], 20, 0xe9b6c7aa); /* 20 */
GG(a, b, c, d, x[ 5], 5, 0xd62f105d); /* 21 */
GG(d, a, b, c, x[10], 9, 0x2441453); /* 22 */
GG(c, d, a, b, x[15], 14, 0xd8a1e681); /* 23 */
GG(b, c, d, a, x[ 4], 20, 0xe7d3fbc8); /* 24 */
GG(a, b, c, d, x[ 9], 5, 0x21e1cde6); /* 25 */
GG(d, a, b, c, x[14], 9, 0xc33707d6); /* 26 */
GG(c, d, a, b, x[ 3], 14, 0xf4d50d87); /* 27 */
GG(b, c, d, a, x[ 8], 20, 0x455a14ed); /* 28 */
GG(a, b, c, d, x[13], 5, 0xa9e3e905); /* 29 */
GG(d, a, b, c, x[ 2], 9, 0xfcefa3f8); /* 30 */
GG(c, d, a, b, x[ 7], 14, 0x676f02d9); /* 31 */
GG(b, c, d, a, x[12], 20, 0x8d2a4c8a); /* 32 */

/* Round 3 */
HH(a, b, c, d, x[ 5], 4, 0xfffa3942); /* 33 */
HH(d, a, b, c, x[ 8], 11, 0x8771f681); /* 34 */
HH(c, d, a, b, x[11], 16, 0x6d9d6122); /* 35 */
HH(b, c, d, a, x[14], 23, 0xfde5380c); /* 36 */
HH(a, b, c, d, x[ 1], 4, 0xa4beea44); /* 37 */
HH(d, a, b, c, x[ 4], 11, 0x4bdecfa9); /* 38 */
HH(c, d, a, b, x[ 7], 16, 0xf6bb4b60); /* 39 */
HH(b, c, d, a, x[10], 23, 0xbebfbc70); /* 40 */
HH(a, b, c, d, x[13], 4, 0x289b7ec6); /* 41 */
HH(d, a, b, c, x[ 0], 11, 0xeaa127fa); /* 42 */
HH(c, d, a, b, x[ 3], 16, 0xd4ef3085); /* 43 */
HH(b, c, d, a, x[ 6], 23, 0x4881d05); /* 44 */
HH(a, b, c, d, x[ 9], 4, 0xd9d4d039); /* 45 */
HH(d, a, b, c, x[12], 11, 0xe6db99e5); /* 46 */
HH(c, d, a, b, x[15], 16, 0x1fa27cf8); /* 47 */
HH(b, c, d, a, x[ 2], 23, 0xc4ac5665); /* 48 */

/* Round 4 */
II(a, b, c, d, x[ 0], 6, 0xf4292244); /* 49 */
II(d, a, b, c, x[ 7], 10, 0x432aff97); /* 50 */
II(c, d, a, b, x[14], 15, 0xab9423a7); /* 51 */
II(b, c, d, a, x[ 5], 21, 0xfc93a039); /* 52 */
II(a, b, c, d, x[12], 6, 0x655b59c3); /* 53 */
II(d, a, b, c, x[ 3], 10, 0x8f0ccc92); /* 54 */
II(c, d, a, b, x[10], 15, 0xffeff47d); /* 55 */
II(b, c, d, a, x[ 1], 21, 0x85845dd1); /* 56 */
II(a, b, c, d, x[ 8], 6, 0x6fa87e4f); /* 57 */
II(d, a, b, c, x[15], 10, 0xfe2ce6e0); /* 58 */
II(c, d, a, b, x[ 6], 15, 0xa3014314); /* 59 */
II(b, c, d, a, x[13], 21, 0x4e0811a1); /* 60 */
II(a, b, c, d, x[ 4], 6, 0xf7537e82); /* 61 */
II(d, a, b, c, x[11], 10, 0xbd3af235); /* 62 */
II(c, d, a, b, x[ 2], 15, 0x2ad7d2bb); /* 63 */
II(b, c, d, a, x[ 9], 21, 0xeb86d391); /* 64 */
state[0] += a;
state[1] += b;
state[2] += c;
state[3] += d;
}

B. C語言實現文件傳輸時用md5加密

搜一下:C語言實現文件傳輸時用md5加密

C. 如何用C語言實現MD5演算法計算一個文本的消息摘要

#include<stdio.h>
#include<string.h>

#define F(x, y, z) (((x) & (y)) | ((~x) & (z)))
#define G(x, y, z) (((x) & (z)) | ((y) & (~z)))
#define H(x, y, z) ((x) ^ (y) ^ (z))
#define I(x, y, z) ((y) ^ ((x) | (~z)))

#define RL(x, y) (((x) << (y)) | ((x) >> (32 - (y)))) //x向左循環移y位

#define PP(x) (x<<24)|((x<<8)&0xff0000)|((x>>8)&0xff00)|(x>>24) //將x高低位互換,例如PP(aabbccdd)=ddccbbaa

#define FF(a, b, c, d, x, s, ac) a = b + (RL((a + F(b,c,d) + x + ac),s))
#define GG(a, b, c, d, x, s, ac) a = b + (RL((a + G(b,c,d) + x + ac),s))
#define HH(a, b, c, d, x, s, ac) a = b + (RL((a + H(b,c,d) + x + ac),s))
#define II(a, b, c, d, x, s, ac) a = b + (RL((a + I(b,c,d) + x + ac),s))

void go_md5(unsigned *a, unsigned *b, unsigned *c, unsigned *d, unsigned *A, unsigned *B, unsigned *C, unsigned *D, unsigned x[]){ //MD5核心演算法,供64輪

*a=*A,*b=*B,*c=*C,*d=*D;
/**//* Round 1 */
FF (*a, *b, *c, *d, x[ 0], 7, 0xd76aa478); /**//* 1 */
FF (*d, *a, *b, *c, x[ 1], 12, 0xe8c7b756); /**//* 2 */
FF (*c, *d, *a, *b, x[ 2], 17, 0x242070db); /**//* 3 */
FF (*b, *c, *d, *a, x[ 3], 22, 0xc1bdceee); /**//* 4 */
FF (*a, *b, *c, *d, x[ 4], 7, 0xf57c0faf); /**//* 5 */
FF (*d, *a, *b, *c, x[ 5], 12, 0x4787c62a); /**//* 6 */
FF (*c, *d, *a, *b, x[ 6], 17, 0xa8304613); /**//* 7 */
FF (*b, *c, *d, *a, x[ 7], 22, 0xfd469501); /**//* 8 */
FF (*a, *b, *c, *d, x[ 8], 7, 0x698098d8); /**//* 9 */
FF (*d, *a, *b, *c, x[ 9], 12, 0x8b44f7af); /**//* 10 */
FF (*c, *d, *a, *b, x[10], 17, 0xffff5bb1); /**//* 11 */
FF (*b, *c, *d, *a, x[11], 22, 0x895cd7be); /**//* 12 */
FF (*a, *b, *c, *d, x[12], 7, 0x6b901122); /**//* 13 */
FF (*d, *a, *b, *c, x[13], 12, 0xfd987193); /**//* 14 */
FF (*c, *d, *a, *b, x[14], 17, 0xa679438e); /**//* 15 */
FF (*b, *c, *d, *a, x[15], 22, 0x49b40821); /**//* 16 */

/**//* Round 2 */
GG (*a, *b, *c, *d, x[ 1], 5, 0xf61e2562); /**//* 17 */
GG (*d, *a, *b, *c, x[ 6], 9, 0xc040b340); /**//* 18 */
GG (*c, *d, *a, *b, x[11], 14, 0x265e5a51); /**//* 19 */
GG (*b, *c, *d, *a, x[ 0], 20, 0xe9b6c7aa); /**//* 20 */
GG (*a, *b, *c, *d, x[ 5], 5, 0xd62f105d); /**//* 21 */
GG (*d, *a, *b, *c, x[10], 9, 0x02441453); /**//* 22 */
GG (*c, *d, *a, *b, x[15], 14, 0xd8a1e681); /**//* 23 */
GG (*b, *c, *d, *a, x[ 4], 20, 0xe7d3fbc8); /**//* 24 */
GG (*a, *b, *c, *d, x[ 9], 5, 0x21e1cde6); /**//* 25 */
GG (*d, *a, *b, *c, x[14], 9, 0xc33707d6); /**//* 26 */
GG (*c, *d, *a, *b, x[ 3], 14, 0xf4d50d87); /**//* 27 */
GG (*b, *c, *d, *a, x[ 8], 20, 0x455a14ed); /**//* 28 */
GG (*a, *b, *c, *d, x[13], 5, 0xa9e3e905); /**//* 29 */
GG (*d, *a, *b, *c, x[ 2], 9, 0xfcefa3f8); /**//* 30 */
GG (*c, *d, *a, *b, x[ 7], 14, 0x676f02d9); /**//* 31 */
GG (*b, *c, *d, *a, x[12], 20, 0x8d2a4c8a); /**//* 32 */

/**//* Round 3 */
HH (*a, *b, *c, *d, x[ 5], 4, 0xfffa3942); /**//* 33 */
HH (*d, *a, *b, *c, x[ 8], 11, 0x8771f681); /**//* 34 */
HH (*c, *d, *a, *b, x[11], 16, 0x6d9d6122); /**//* 35 */
HH (*b, *c, *d, *a, x[14], 23, 0xfde5380c); /**//* 36 */
HH (*a, *b, *c, *d, x[ 1], 4, 0xa4beea44); /**//* 37 */
HH (*d, *a, *b, *c, x[ 4], 11, 0x4bdecfa9); /**//* 38 */
HH (*c, *d, *a, *b, x[ 7], 16, 0xf6bb4b60); /**//* 39 */
HH (*b, *c, *d, *a, x[10], 23, 0xbebfbc70); /**//* 40 */
HH (*a, *b, *c, *d, x[13], 4, 0x289b7ec6); /**//* 41 */
HH (*d, *a, *b, *c, x[ 0], 11, 0xeaa127fa); /**//* 42 */
HH (*c, *d, *a, *b, x[ 3], 16, 0xd4ef3085); /**//* 43 */
HH (*b, *c, *d, *a, x[ 6], 23, 0x04881d05); /**//* 44 */
HH (*a, *b, *c, *d, x[ 9], 4, 0xd9d4d039); /**//* 45 */
HH (*d, *a, *b, *c, x[12], 11, 0xe6db99e5); /**//* 46 */
HH (*c, *d, *a, *b, x[15], 16, 0x1fa27cf8); /**//* 47 */
HH (*b, *c, *d, *a, x[ 2], 23, 0xc4ac5665); /**//* 48 */

/**//* Round 4 */
II (*a, *b, *c, *d, x[ 0], 6, 0xf4292244); /**//* 49 */
II (*d, *a, *b, *c, x[ 7], 10, 0x432aff97); /**//* 50 */
II (*c, *d, *a, *b, x[14], 15, 0xab9423a7); /**//* 51 */
II (*b, *c, *d, *a, x[ 5], 21, 0xfc93a039); /**//* 52 */
II (*a, *b, *c, *d, x[12], 6, 0x655b59c3); /**//* 53 */
II (*d, *a, *b, *c, x[ 3], 10, 0x8f0ccc92); /**//* 54 */
II (*c, *d, *a, *b, x[10], 15, 0xffeff47d); /**//* 55 */
II (*b, *c, *d, *a, x[ 1], 21, 0x85845dd1); /**//* 56 */
II (*a, *b, *c, *d, x[ 8], 6, 0x6fa87e4f); /**//* 57 */
II (*d, *a, *b, *c, x[15], 10, 0xfe2ce6e0); /**//* 58 */
II (*c, *d, *a, *b, x[ 6], 15, 0xa3014314); /**//* 59 */
II (*b, *c, *d, *a, x[13], 21, 0x4e0811a1); /**//* 60 */
II (*a, *b, *c, *d, x[ 4], 6, 0xf7537e82); /**//* 61 */
II (*d, *a, *b, *c, x[11], 10, 0xbd3af235); /**//* 62 */
II (*c, *d, *a, *b, x[ 2], 15, 0x2ad7d2bb); /**//* 63 */
II (*b, *c, *d, *a, x[ 9], 21, 0xeb86d391); /**//* 64 */

*A += *a;
*B += *b;
*C += *c;
*D += *d;

}

void get_x(char *p_str, unsigned *pa_x)
{
int k = 0;
int i = 0;
int j;
int f = 0;
int g,h;
while (p_str[k] != 0)
{
g = k+3;
while (i < 4)
{
if (p_str[g] == 0)
{
g--;
i++;

continue;
}
pa_x[f] = pa_x[f]*16*16+p_str[g];
i++;
g--;
k++;

}
f++;
i = 0;

}
}

int main()
{
char ch[7] = "123456";

char *p;
p = ch;
int f = 0, j;
unsigned A,B,C,D,a,b,c,d,i,len,flen[2],x[16]; //i臨時變數,len文件長,flen[2]為64位二進製表示的文件初始長度
A = 0x67452301, B = 0xefcdab89, C = 0x98badcfe, D = 0x10325476; //初始化鏈接變數
len = strlen(p);
flen[1] = len / 0x20000000; //flen單位是bit
flen[0] = (len % 0x20000000) * 8;
memset(x,0,64); //初始化x數組為0

get_x(ch, x);
for(i=0;i<len/64;i++)
{ //循環運算直至文件結束
go_md5(&a,&b,&c,&d,&A,&B,&C,&D,x);
memset(x,0,64);
get_x(ch, x);
}
((char*)x)[len % 64] = 128;
if(len%64>55)
{
go_md5(&a,&b,&c,&d,&A,&B,&C,&D,x);
memset(x,0,64);
}
memcpy(x + 14, flen, 8);
go_md5(&a,&b,&c,&d,&A,&B,&C,&D,x);
printf("MD5 Code:%08x%08x%08x%08x\n",PP(A),PP(B),PP(C),PP(D));
getch();
return 0;
}
我自己修改的,在devcpp通過,

D. C語言求文件MD5的函數用法

C語言沒有內置的MD5函數,可以在以下頁面找到C語言實現程序和MD5的演算法介紹:

http://tools.ietf.org/html/rfc1321

E. 求個C語言的socket通信程序,要求服務端計算文件的MD5值並發送,之後才發送正文內容....求高手指教

我不太清楚你說的文件是大文件還是小文件(小於8K的),如果是大文件,可以定義一個簡單的協議,比如,規定3個欄位
消息類型
消息長度
消息內容
每個消息可以定義一個最大長度,每次收到消息時首先判定消息類型,比如你可以規定1為請求文件的MD5值,消息的內容為文件的路徑,消息的長度欄位就可以規定消息內容的長度,伺服器返回時,可以讓消息內容為文件的MD5值;而2可以定義為發送的消息內容是文件的內容(原始文件被分成多段傳送);3就可以定義為文件內容傳送結束,此時客戶端就可以關閉文件就行MD5校驗,看是否與之前收到的伺服器發送的MD5一致。

如果是簡單的文件傳送,對效率要求不高,可以簡單地採用TCP單線程傳送,如果對效率要求較高可以考慮採用UDP進行傳送,不過此時協議需要增加超時機制,還要設置包的序號,防止錯位。

其實你這個程序就只有兩個部分,一個是socket通信,另一個就是MD5值的校驗,前者不論是TCP還是UDP都有現成的模板,後者MD5的演算法肯定不需要你我去寫,肯定也有現成的函數庫調用,所以實現起來應該不困難。

F. 請教MD5演算法 用C語言實現

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#ifdefined(__APPLE__)
#defineCOMMON_DIGEST_FOR_OPENSSL
#include<CommonCrypto/CommonDigest.h>
#defineSHA1CC_SHA1
#else
#include<openssl/md5.h>
#endif

//這是我自己寫的函數,用於計算MD5
//參數str:要轉換的字元串
//參數lengthL:字元串的長度可以用strlen(str)直接獲取參數str的長度
//返回值:MD5字元串
char*str2md5(constchar*str,intlength){
intn;
MD5_CTXc;
unsignedchardigest[16];
char*out=(char*)malloc(33);

MD5_Init(&c);

while(length>0){
if(length>512){
MD5_Update(&c,str,512);
}else{
MD5_Update(&c,str,length);
}
length-=512;
str+=512;
}

MD5_Final(digest,&c);

for(n=0;n<16;++n){
snprintf(&(out[n*2]),16*2,"%02x",(unsignedint)digest[n]);
}

returnout;
}

intmain(intargc,char**argv){
char*output=str2md5("hello",strlen("hello"));

printf("%s ",output);
//上面會輸出hello的MD5字元串:
//
free(output);
return0;
}

G. 如何計算一個文件的md5值

文件校驗和完整性驗證程序 (FCIV) 實用程序可以用於計算 MD5 或 sha-1 加密哈希值的文件。 有關文件校驗和完整性驗證程序 (FCIV) 實用程序的其他信息,請單擊下面的文章編號,以查看 Microsoft 知識庫中相應的文章: 841290可用性和文件校驗和完整性驗證程序實用程序的說明 若要計算在 MD5 和文件的 sha-1 哈希值,請在命令行鍵入以下命令: FCIV-md5-sha1 path\filename.ext 例如對於計算 Shdocvw.dll 文件 %Systemroot% \System32 文件夾中的 MD5 和 sha-1 哈希值,鍵入以下命令: FCIV-md5-sha1 c:\windows\system32\shdocvw.dll

H. c語言md5程序裡面有文件位操作不懂 達人請進

0x2000 0000在這里是16進制數 轉換成十進制數是536870912bit = 67108864 BYTE = 65536 KB = 64MB
/* flen[1]=len/0x20000000; //flen單位是bit */
這行指令做的是 看那個被打開的文件的長度是64兆的多少倍 並且把計算出的結果(倍數)放到array flen[1]里(file length)並且存進去的是個整數 文件長度是個很長的很奇怪的數 除個536870912這么個怪數肯定不會是個整數(至少大多情況下)

所以有了下面這一行指令
/* flen[0]=(len%0x20000000)*8; */
這行指令把file length除64MB這個數的余數提出 並且乘了8(即除以64MB 余數* 8 讓BYTE單位變成bit單位) 為程序的後面做運算做鋪墊或者准備
並且存在了flen[0]里

這個程序不全 我想提問題的人應該有全的版本 我能給的幫助就這么多 希望能幫到你:)

I. 求一個計算文件MD5的程序(C或C++都行)

#include <stdio.h>
#include <stdlib.h>
#include <memory.h>
#include <math.h>
#include "windows.h"typedef unsigned char BYTE;
typedef unsigned int UINT;
typedef UINT MD5_SUB_ARRAY[16];
typedef UINT MD5_TRANSORM_FUNC(UINT,UINT,UINT);
typedef struct
{
UINT a;
UINT b;
UINT c;
UINT d;
MD5_SUB_ARRAY sub_array;
}MD5_TRANSFORM_PARAM;const double MAX_INT = (double)0xFFFFFFFF + 1.0;const UINT MD5_TRANSFORM_MATRIX[4][16][3] =
{{
{ 0, 7, 1}, { 1,12, 2}, { 2,17, 3}, { 3,22, 4},
{ 4, 7, 5}, { 5,12, 6}, { 6,17, 7}, { 7,22, 8},
{ 8, 7, 9}, { 9,12,10}, {10,17,11}, {11,22,12},
{12, 7,13}, {13,12,14}, {14,17,15}, {15,22,16},
},{
{ 1, 5,17}, { 6, 9,18}, {11,14,19}, { 0,20,20},
{ 5, 5,21}, {10, 9,22}, {15,14,23}, { 4,20,24},
{ 9, 5,25}, {14, 9,26}, { 3,14,27}, { 8,20,28},
{13, 5,29}, { 2, 9,30}, { 7,14,31}, {12,20,32},
},{
{5, 4, 33}, { 8,11,34}, {11,16,35},{14, 23,36},
{1, 4, 37}, { 4,11,38}, { 7,16,39},{10, 23,40},fayer
{13,4, 41}, { 0,11,42}, { 3,16,43},{ 6, 23,44},
{9, 4, 45}, {12,11,46}, {15,16,47},{ 2, 23,48},
},{
{ 0,6,49}, { 7,10,50}, {14,15,51},{ 5, 21,52},
{12,6,53}, { 3,10,54}, {10,15,55},{ 1, 21,56},
{ 8,6,57}, {15,10,58}, { 6,15,59},{13, 21,60},
{ 4,6,61}, {11,10,62}, { 2,15,63},{ 9, 21,64},
},
};static UINT MD5_TRANSFORM_ARRAY[65];void MD5_Init()
{
int x;
for(x = 1; x <= 64; x++)
{
MD5_TRANSFORM_ARRAY[fayer] = (UINT)(MAX_INT * fabs(sin(x)));
}
}UINT F(UINT x,UINT y,UINT z)
{
return ((x & y) | ((~x) & z));
}UINT G(UINT x,UINT y,UINT z)
{
return ((x & z) | (y & (~z)));
}UINT H(UINT x,UINT y,UINT z)
{
return (x ^ y ^ z);
}UINT I(UINT x,UINT y,UINT z)
{
return (y ^ (x | (~z)));
} BYTE* MD5_prepare_data(const BYTE* data,int len,int* new_len)
{
int rest,fill,size;
BYTE* new_data;
UINT bit_len;// (1) 位元組補齊
rest = len % 56;
if (rest <= 56) fill = 56 - rest;
else fill = (64 - rest) + 56;new_data = (BYTE*)malloc(len + fill + 8);
if (NULL == new_data) return NULL;if (len > 0) memcpy(new_data,datafayer,len);
if (fill > 0) memset(new_data + len,0x80,1);
if (fill > 1) memset(new_data + len + 1,0,fill - 1);size = fill + len;// (2) 附加數據的比特長度
bit_len = len * 8;
// (64位二進制數表示的)比特長度的低32位
memset(new_data + size + 0,(bit_len & 0x000000FF), 1);
memset(new_data + size + 1,(bit_len & 0x0000FF00) >> 8, 1);

// 不考慮比特長度超出32位無符號數表示範圍,所以高32位總是0
memset(new_data + size + 4,0,4);*new_len = size + 8;return new_data;
}void MD5_transform(MD5_TRANSFORM_PARAM* param,int ring,MD5_TRANSORM_FUNC func)
{
UINT a,b,c,d,s,k,i;
UINT abcd[4];
UINT *X,*T;
int index;abcd[0] = param->a;
abcd[1] = param->b;
abcd[2] = param->c;
abcd[3] = param->d;
X = param->sub_array;
T = MD5_TRANSFORM_ARRAY;for(index = 0; index < 16; index++)
{
a = abcd[(3 * index + 0) % 4];
b = abcd[(3 * index + 1) % 4];
c = abcd[(3 * index + 2) % 4];
d = abcd[(3 * index + 3) % 4];k = MD5_TRANSFORM_MATRIX[ring][index][0];
s = MD5_TRANSFORM_MATRIX[ring][index][1];
i = MD5_TRANSFORM_MATRIX[ring][index][2];a = a + func(b,c,d) + X[k] + T[i];
a = ( a << s) | ( a >> (32 - s)); // 循環左移
a = a + b;abcd[(3 * index + 0) % 4] = a;
}param->a = abcd[0];
param->b = abcd[1];
param->c = abcd[2];
param->d = abcd[3];
}int MD5(const BYTE* data,int len)
{int x,y,new_len;
MD5_TRANSFORM_PARAM param;
UINT AA,BB,CC,DD;
BYTE* buf;MD5_Init();buf = MD5_prepare_data(data,len,&new_len);
if (buf == NULL) return -1;AA = 0x67452301;
BB = 0xefcdab89;
CC = 0x98badcfe;
DD = 0x10325476;for(x = 0; x < new_len / 64; x++)
{
param.a = AA;
param.b = BB;
param.c = CC;
param.d = DD;for(y = 0; y < 16; y++)
{
param.sub_array[y] = buf[64 * x + 4 * y + 0];
param.sub_array[y] += buf[64 * x + 4 * y + 1] << 8;
param.sub_array[y] += buf[64 * x + 4 * y + 2] << 16;
param.sub_array[y] += buf[64 * x + 4 * y + 3] << 24;
}
MD5_transform(¶m,0,F);
MD5_transform(¶m,1,G);
MD5_transform(¶m,2,H);
MD5_transform(¶m,3,I);AA += param.a;
BB += param.b;
CC += param.c;
DD += param.d;
}printf("MD5(\"%s\")=",data);printf("%02X%02X%02X%02X",
(AA & 0x000000FF),
(AA & 0x0000FF00) >> 8,
(AA & 0x00FF0000) >> 16,
(AA & 0xFF000000) >> 24);printf("%02X%02X%02X%02X",
(BB & 0x000000FF),
(BB & 0x0000FF00) >> 8,
(BB & 0x00FF0000) >> 16,
(BB & 0xFF000000) >> 24);printf("%02X%02X%02X%02X",
(CC & 0x000000FF),
(CC & 0x0000FF00) >> 8,
(CC & 0x00FF0000) >> 16,
(CC & 0xFF000000) >> 24);printf("%02X%02X%02X%02X",
(DD & 0x000000FF),
(DD & 0x0000FF00) >> 8,
(DD & 0x00FF0000) >> 16,
(DD & 0xFF000000) >> 24);printf("\n");return 0;
}
int main()
{
MD5((unsigned char *)"",0);//這里需要將待處理的字元串強制類型轉化為unsigned char *,保持和MD5()參數類型的一致。
MD5((unsigned char *)"a",1);
MD5((unsigned char *)"abc",3);
MD5((unsigned char *)"message digest",14);
MD5((unsigned char *)"abcdefghijklmnopqrstuvwxyz",26);return 0;
}

J. C語言中md5的數據讀取與填充

查閱fread函數,可以實現按照位元組批次讀取,你的文件最好用二進制方式打開。
查閱剩餘數據,恐怕得實際讀取才知道,但是每次讀取文件都會改變文件指針的位置,你需要用fseek來移動文件指針回到原本的位置。
函數 size_t fread(void * ptr,size_t size,size_t nmemb,FILE * stream);函數說明 fread()用來從文件流中讀取數據。參數stream為已打開的文件指針,參數ptr 指向欲存放
讀取進來的數據空間,讀取的字元數以參數size*nmemb來決定。Fread()會返回實際讀取到的nmemb數目,
如果此值比參數nmemb 來得小,則代表可能讀到了文件尾或有錯誤發生,這時必須用feof()或ferror()
來決定發生什麼情況。

熱點內容
網易我的世界租賃伺服器怎麼開作弊 發布:2025-01-10 07:53:27 瀏覽:233
ftp伺服器功能 發布:2025-01-10 07:48:33 瀏覽:80
java如何運行程序 發布:2025-01-10 07:25:53 瀏覽:562
冒險島電腦連接伺服器失敗 發布:2025-01-10 07:23:01 瀏覽:824
安卓開發要學什麼語言 發布:2025-01-10 07:21:30 瀏覽:21
紹興編程培訓 發布:2025-01-10 07:16:53 瀏覽:300
java介面和類 發布:2025-01-10 07:09:14 瀏覽:403
discuzforlinux安裝 發布:2025-01-10 07:09:10 瀏覽:229
招行支票密碼器口令是多少 發布:2025-01-10 06:55:27 瀏覽:353
好的解壓拓展實力怎麼樣 發布:2025-01-10 06:49:18 瀏覽:699