md5源码(md5源码实现)

2023-02-18 12:06:02 密语知识 思思

求密码学课程设计 MD5的实现 源代码 高分

我有C语言的实现代码。

你把下面的代码复制下来,保存成md5lib.h,然后在C代码中:

#include "md5lib.h" 即可

其中:

char* MDString (char *string);是对字符串进行MD5

char* MDFile (char *filename);是对文件进行MD5

以下是代码

//--------------------------------

/* MD5lib.h - md5 library

*/

/* Copyright (C) 1990-2, RSA Data Security, Inc. Created 1990. All

rights reserved.

RSA Data Security, Inc. makes no representations concerning either

the merchantability of this software or the suitability of this

software for any particular purpose. It is provided "as is"

without express or implied warranty of any kind.

These notices must be retained in any copies of any part of this

documentation and/or software.

*/

/* The following makes MD default to MD5 if it has not already been

defined with C compiler flags.

*/

#include stdio.h

#include time.h

#include string.h

#define MD 5

/* GLOBAL.H - RSAREF types and constants

*/

/* PROTOTYPES should be set to one if and only if the compiler supports

function argument prototyping.

The following makes PROTOTYPES default to 0 if it has not already

been defined with C compiler flags.

*/

#ifndef PROTOTYPES

#define PROTOTYPES 0

#endif

/* POINTER defines a generic pointer type */

typedef unsigned char *POINTER;

/* UINT2 defines a two byte word */

typedef unsigned short int UINT2;

/* UINT4 defines a four byte word */

typedef unsigned long int UINT4;

/* PROTO_LIST is defined depending on how PROTOTYPES is defined above.

If using PROTOTYPES, then PROTO_LIST returns the list, otherwise it

returns an empty list.

*/

#if PROTOTYPES

#define PROTO_LIST(list) list

#else

#define PROTO_LIST(list) ()

#endif

/* Length of test block, number of test blocks.

*/

#define TEST_BLOCK_LEN 1000

#define TEST_BLOCK_COUNT 1000

/* Constants for MD5Transform routine.

*/

#define S11 7

#define S12 12

#define S13 17

#define S14 22

#define S21 5

#define S22 9

#define S23 14

#define S24 20

#define S31 4

#define S32 11

#define S33 16

#define S34 23

#define S41 6

#define S42 10

#define S43 15

#define S44 21

char* MDString PROTO_LIST ((char *));

char* MDFile PROTO_LIST ((char *));

char* hmac_md5(char* text, char* key);

typedef struct {

UINT4 state[4]; /* state (ABCD) */

UINT4 count[2]; /* number of bits, modulo 2^64 (lsb first) */

unsigned char buffer[64]; /* input buffer */

} MD5_CTX;

/*void MD5Init PROTO_LIST ((MD5_CTX *));

void MD5Update PROTO_LIST

((MD5_CTX *, unsigned char *, unsigned int));

void MD5Final PROTO_LIST ((unsigned char [16], MD5_CT X *));

static void MD5Transform PROTO_LIST ((UINT4 [4], unsigned char [64]));

static void Encode PROTO_LIST

((unsigned char *, UINT4 *, unsigned int));

static void Decode PROTO_LIST

((UINT4 *, unsigned char *, unsigned int));

static void MD5_memcpy PROTO_LIST ((POINTER, POINTER, unsigned int));

static void MD5_memset PROTO_LIST ((POINTER, int, unsigned int));

*/

static unsigned char PADDING[64] = {

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

};

/* F, G, H and I are basic MD5 functions.

*/

#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)))

/* ROTATE_LEFT rotates x left n bits.

*/

#define ROTATE_LEFT(x, n) (((x) (n)) | ((x) (32-(n))))

/* FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4.

Rotation is separate from addition to prevent recomputation.

*/

#define FF(a, b, c, d, x, s, ac) {(a) += F ((b), (c), (d)) + (x) + (UINT4)(ac); (a) = ROTATE_LEFT ((a), (s)); (a) += (b);}

#define GG(a, b, c, d, x, s, ac) {(a) += G ((b), (c), (d)) + (x) + (UINT4)(ac); (a) = ROTATE_LEFT ((a), (s)); (a) += (b);}

#define HH(a, b, c, d, x, s, ac) {(a) += H ((b), (c), (d)) + (x) + (UINT4)(ac); (a) = ROTATE_LEFT ((a), (s)); (a) += (b);}

#define II(a, b, c, d, x, s, ac) {(a) += I ((b), (c), (d)) + (x) + (UINT4)(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 (unsigned char digest[16], MD5_CTX *context);

static void MD5Transform (UINT4 [4], unsigned char [64]) ;

static void Encode(unsigned char *, UINT4 *, unsigned int);

static void Decode (UINT4 *, unsigned char *, unsigned int);

static void MD5_memcpy(POINTER, POINTER, unsigned int);

static void MD5_memset(POINTER, int, unsigned int);

/* MD5 initialization. Begins an MD5 operation, writing a new context.

*/

void MD5Init (MD5_CTX *context)

/* context */

{

context-count[0] = context-count[1] = 0;

/* Load magic initialization constants.

*/

context-state[0] = 0x67452301;

context-state[1] = 0xefcdab89;

context-state[2] = 0x98badcfe;

context-state[3] = 0x10325476;

}

/* MD5 block update operation. Continues an MD5 message-digest

operation, processing another message block, and updating the

context.

*/

void MD5Update (MD5_CTX *context, unsigned char *input,unsigned int inputLen )

/* context */

/* input block */

/* length of input block */

{

unsigned int i, index, partLen;

/* Compute number of bytes mod 64 */

index = (unsigned int)((context-count[0] 3) 0x3F);

/* Update number of bits */

if ((context-count[0] += ((UINT4)inputLen 3))

((UINT4)inputLen 3))

context-count[1]++;

context-count[1] += ((UINT4)inputLen 29);

partLen = 64 - index;

/* Transform as many times as possible.

*/

if (inputLen = partLen) {

MD5_memcpy

((POINTER)context-buffer[index], (POINTER)input, partLen);

MD5Transform (context-state, context-buffer);

for (i = partLen; i + 63 inputLen; i += 64)

MD5Transform (context-state, input[i]);

index = 0;

}

else

i = 0;

/* Buffer remaining input */

MD5_memcpy

((POINTER)context-buffer[index], (POINTER)input[i],

inputLen-i);

}

/* MD5 finalization. Ends an MD5 message-digest operation, writing the

the message digest and zeroizing the context.

*/

void MD5Final (unsigned char digest[16], MD5_CTX *context)

/* message digest */

/* context */

{

unsigned char bits[8];

unsigned int index, padLen;

/* Save number of bits */

Encode (bits, context-count, 8);

/* Pad out to 56 mod 64.

*/

index = (unsigned int)((context-count[0] 3) 0x3f);

padLen = (index 56) ? (56 - index) : (120 - index);

MD5Update (context,(unsigned char*) PADDING, padLen);

/* Append length (before padding) */

MD5Update (context, bits, 8);

/* Store state in digest */

Encode (digest, context-state, 16);

/* Zeroize sensitive information.

*/

MD5_memset ((POINTER)context, 0, sizeof (*context));

}

/* MD5 basic transformation. Transforms state based on block.

*/

static void MD5Transform (UINT4 state[4],

unsigned char block[64])

{

int i=0;

UINT4 a = state[0], b = state[1], c = state[2], d = state[3], x[16];

Decode (x, block, 64);

/* Round 1 */

FF (a, b, c, d, x[ 0], S11, 0xd76aa478); /* 1 */

FF (d, a, b, c, x[ 1], S12, 0xe8c7b756); /* 2 */

FF (c, d, a, b, x[ 2], S13, 0x242070db); /* 3 */

FF (b, c, d, a, x[ 3], S14, 0xc1bdceee); /* 4 */

FF (a, b, c, d, x[ 4], S11, 0xf57c0faf); /* 5 */

FF (d, a, b, c, x[ 5], S12, 0x4787c62a); /* 6 */

FF (c, d, a, b, x[ 6], S13, 0xa8304613); /* 7 */

FF (b, c, d, a, x[ 7], S14, 0xfd469501); /* 8 */

FF (a, b, c, d, x[ 8], S11, 0x698098d8); /* 9 */

FF (d, a, b, c, x[ 9], S12, 0x8b44f7af); /* 10 */

FF (c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */

FF (b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */

FF (a, b, c, d, x[12], S11, 0x6b901122); /* 13 */

FF (d, a, b, c, x[13], S12, 0xfd987193); /* 14 */

FF (c, d, a, b, x[14], S13, 0xa679438e); /* 15 */

FF (b, c, d, a, x[15], S14, 0x49b40821); /* 16 */

/* Round 2 */

GG (a, b, c, d, x[ 1], S21, 0xf61e2562); /* 17 */

GG (d, a, b, c, x[ 6], S22, 0xc040b340); /* 18 */

GG (c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */

GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa); /* 20 */

GG (a, b, c, d, x[ 5], S21, 0xd62f105d); /* 21 */

GG (d, a, b, c, x[10], S22, 0x2441453); /* 22 */

GG (c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */

GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8); /* 24 */

GG (a, b, c, d, x[ 9], S21, 0x21e1cde6); /* 25 */

GG (d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */

GG (c, d, a, b, x[ 3], S23, 0xf4d50d87); /* 27 */

GG (b, c, d, a, x[ 8], S24, 0x455a14ed); /* 28 */

GG (a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */

GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8); /* 30 */

GG (c, d, a, b, x[ 7], S23, 0x676f02d9); /* 31 */

GG (b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */

/* Round 3 */

HH (a, b, c, d, x[ 5], S31, 0xfffa3942); /* 33 */

HH (d, a, b, c, x[ 8], S32, 0x8771f681); /* 34 */

HH (c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */

HH (b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */

HH (a, b, c, d, x[ 1], S31, 0xa4beea44); /* 37 */

HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9); /* 38 */

HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60); /* 39 */

HH (b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */

HH (a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */

HH (d, a, b, c, x[ 0], S32, 0xeaa127fa); /* 42 */

HH (c, d, a, b, x[ 3], S33, 0xd4ef3085); /* 43 */

HH (b, c, d, a, x[ 6], S34, 0x4881d05); /* 44 */

HH (a, b, c, d, x[ 9], S31, 0xd9d4d039); /* 45 */

HH (d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */

HH (c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */

HH (b, c, d, a, x[ 2], S34, 0xc4ac5665); /* 48 */

/* Round 4 */

II (a, b, c, d, x[ 0], S41, 0xf4292244); /* 49 */

II (d, a, b, c, x[ 7], S42, 0x432aff97); /* 50 */

II (c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */

II (b, c, d, a, x[ 5], S44, 0xfc93a039); /* 52 */

II (a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */

II (d, a, b, c, x[ 3], S42, 0x8f0ccc92); /* 54 */

II (c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */

II (b, c, d, a, x[ 1], S44, 0x85845dd1); /* 56 */

II (a, b, c, d, x[ 8], S41, 0x6fa87e4f); /* 57 */

II (d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */

II (c, d, a, b, x[ 6], S43, 0xa3014314); /* 59 */

II (b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */

II (a, b, c, d, x[ 4], S41, 0xf7537e82); /* 61 */

II (d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */

II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb); /* 63 */

II (b, c, d, a, x[ 9], S44, 0xeb86d391); /* 64 */

state[0] += a;

state[1] += b;

state[2] += c;

state[3] += d;

/* Zeroize sensitive information.

*/

MD5_memset ((POINTER)x, 0, sizeof (x));

}

/* Encodes input (UINT4) into output (unsigned char). Assumes len is

a multiple of 4.

*/

static void Encode (unsigned char *output,

UINT4 *input,

unsigned int len)

{

unsigned int i, j;

for (i = 0, j = 0; j len; i++, j += 4) {

output[j] = (unsigned char)(input[i] 0xff);

output[j+1] = (unsigned char)((input[i] 8) 0xff);

output[j+2] = (unsigned char)((input[i] 16) 0xff);

output[j+3] = (unsigned char)((input[i] 24) 0xff);

}

}

/* Decodes input (unsigned char) into output (UINT4). Assumes len is

a multiple of 4.

*/

static void Decode (UINT4 *output,

unsigned char *input,

unsigned int len)

{

unsigned int i, j;

for (i = 0, j = 0; j len; i++, j += 4)

output[i] = ((UINT4)input[j]) | (((UINT4)input[j+1]) 8) |

(((UINT4)input[j+2]) 16) | (((UINT4)input[j+3]) 24);

}

/* Note: Replace "for loop" with standard memcpy if possible.

*/

static void MD5_memcpy (POINTER output,

POINTER input,

unsigned int len)

{

unsigned int i;

for (i = 0; i len; i++)

output[i] = input[i];

}

/* Note: Replace "for loop" with standard memset if possible.

*/

static void MD5_memset (POINTER output,

int value,

unsigned int len)

{

unsigned int i;

for (i = 0; i len; i++)

((char *)output)[i] = (char)value;

}

/* Digests a string and prints the result.

*/

char* MDString (char *string)

{

MD5_CTX context;

unsigned char digest[16];

char output1[32];

static char output[33]={""};

unsigned int len = strlen (string);

int i;

MD5Init (context);

MD5Update (context, (unsigned char*)string, len);

MD5Final (digest, context);

for (i = 0; i 16; i++)

{sprintf((output1[2*i]),"%02x",(unsigned char)digest[i]);

sprintf((output1[2*i+1]),"%02x",(unsigned char)(digest[i]4));

}

for(i=0;i32;i++)

output[i]=output1[i];

return output;

}

/* Digests a file and prints the result.

*/

char* MDFile (char *filename)

{ static char output[33]={""};

FILE *file;

MD5_CTX context;

int len;

unsigned char buffer[1024], digest[16];

int i;

char output1[32];

if ((file = fopen (filename, "rb")) == NULL)

{ printf ("%s can't be openedn", filename);

return 0;

}

else {

MD5Init (context);

while (len = fread (buffer, 1, 1024, file))

MD5Update (context, buffer, len);

MD5Final (digest, context);

fclose (file);

for (i = 0; i 16; i++)

{sprintf((output1[2*i]),"%02x",(unsigned char)digest[i]);

sprintf((output1[2*i+1]),"%02x",(unsigned char)(digest[i]4));

}

for(i=0;i32;i++)

output[i]=output1[i];

return output;

}

}

char* hmac_md5(char* text,char* key)

{

char digest[16];

char output1[32];

static char output[33]={""};

MD5_CTX context;

unsigned char k_ipad[65]; /* inner padding -

* key XORd with ipad

*/

unsigned char k_opad[65]; /* outer padding -

* key XORd with opad

*/

unsigned char tk[16];

int i;

int text_len = strlen (text);

int key_len=strlen(key);

/* if key is longer than 64 bytes reset it to key=MD5(key) */

if (key_len 64) {

MD5_CTX tctx;

MD5Init(tctx);

MD5Update(tctx,(unsigned char*) key, key_len);

MD5Final(tk, tctx);

key = (char*)tk;

key_len = 16;

}

/*

* the HMAC_MD5 transform looks like:

*

* MD5(K XOR opad, MD5(K XOR ipad, text))

*

* where K is an n byte key

* ipad is the byte 0x36 repeated 64 times

* opad is the byte 0x5c repeated 64 times

* and text is the data being protected

*/

/* start out by storing key in pads */

/*bzero( k_ipad, sizeof k_ipad);

bzero( k_opad, sizeof k_opad);

*/

for(i=0;i65;i++)

k_ipad[i]=(unsigned char)0;

for(i=0;i65;i++)

k_opad[i]=(unsigned char)0;

/*bcopy( key, k_ipad, key_len);

bcopy( key, k_opad, key_len);

*/

for(i=0;ikey_len;i++)

{k_ipad[i]=(unsigned char)key[i];

k_opad[i]=(unsigned char)key[i];

}

/* XOR key with ipad and opad values */

for (i=0; i64; i++) {

k_ipad[i] ^= 0x36;

k_opad[i] ^= 0x5c;

}

/*

* perform inner MD5

*/

MD5Init(context); /* init context for 1st

* pass */

MD5Update(context, k_ipad, 64); /* start with inner pad */

MD5Update(context, (unsigned char*)text, text_len); /* then text of datagram

*/

MD5Final((unsigned char*)digest, context); /* finish up 1st pass */

/*

* perform outer MD5

*/

MD5Init(context); /* init context for 2nd

* pass */

MD5Update(context, k_opad, 64); /* start with outer pad */

MD5Update(context,(unsigned char*) digest, 16); /* then results of 1st

* hash */

MD5Final((unsigned char*)digest, context); /* finish up 2nd pass */

for (i = 0; i 16; i++)

{sprintf((output1[2*i]),"%02x",(unsigned char)digest[i]);

sprintf((output1[2*i+1]),"%02x",(unsigned char)(digest[i]4));

}

for(i=0;i32;i++)

output[i]=output1[i];

return output;

}

md5源码(md5源码实现) 第1张

急求 MD5的加密解密算法,用C++实现的源代码 高分答谢

要代码,还是要相关的解释资料?

---------------------------------

要代码的话:

两个文件:

--------------------------

1. md5.h:

#pragma once

typedef unsigned long int UINT32;

typedef unsigned short int UINT16;

/* MD5 context. */

typedef struct {

UINT32 state[4]; /* state (ABCD) */

UINT32 count[2]; /* number of bits, modulo 2^64 (lsb first) */

unsigned char buffer[64]; /* input buffer */

} MD5_CTX;

void MD5Init (MD5_CTX *);

void MD5Update (MD5_CTX *, unsigned char *, unsigned int);

void MD5Final (unsigned char [16], MD5_CTX *);

--------------------------

2. md5.cpp:

#include "md5.h"

#include "memory.h"

#define S11 7

#define S12 12

#define S13 17

#define S14 22

#define S21 5

#define S22 9

#define S23 14

#define S24 20

#define S31 4

#define S32 11

#define S33 16

#define S34 23

#define S41 6

#define S42 10

#define S43 15

#define S44 21

static void MD5Transform (UINT32 a[4], unsigned char b[64]);

static void Encode (unsigned char *, UINT32 *, unsigned int);

static void Decode (UINT32 *, unsigned char *, unsigned int);

static unsigned char PADDING[64] = {

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

};

#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) + (UINT32)(ac); \

(a) = ROTATE_LEFT ((a), (s)); \

(a) += (b); \

}

#define GG(a, b, c, d, x, s, ac) { \

(a) += G ((b), (c), (d)) + (x) + (UINT32)(ac); \

(a) = ROTATE_LEFT ((a), (s)); \

(a) += (b); \

}

#define HH(a, b, c, d, x, s, ac) { \

(a) += H ((b), (c), (d)) + (x) + (UINT32)(ac); \

(a) = ROTATE_LEFT ((a), (s)); \

(a) += (b); \

}

#define II(a, b, c, d, x, s, ac) { \

(a) += I ((b), (c), (d)) + (x) + (UINT32)(ac); \

(a) = ROTATE_LEFT ((a), (s)); \

(a) += (b); \

}

void MD5Init (MD5_CTX *context)

{

context-count[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, index, partLen;

index = (unsigned int)((context-count[0] 3) 0x3F);

if ((context-count[0] += ((UINT32)inputLen 3))

((UINT32)inputLen 3))

context-count[1]++;

context-count[1] += ((UINT32)inputLen 29);

partLen = 64 - index;

if (inputLen = partLen) {

memcpy((unsigned char *)context-buffer[index], (unsigned char *)input, partLen);

MD5Transform (context-state, context-buffer);

for (i = partLen; i + 63 inputLen; i += 64)

MD5Transform (context-state, input[i]);

index = 0;

}

else

i = 0;

memcpy((unsigned char *)context-buffer[index], (unsigned char *)input[i],

inputLen-i);

}

void MD5Final (unsigned char digest[16], MD5_CTX * context)

{

unsigned char bits[8];

unsigned int index, padLen;

Encode (bits, context-count, 8);

index = (unsigned int)((context-count[0] 3) 0x3f);

padLen = (index 56) ? (56 - index) : (120 - index);

MD5Update (context, PADDING, padLen);

MD5Update (context, bits, 8);

Encode (digest, context-state, 16);

memset ((unsigned char *)context, 0, sizeof (*context));

}

static void MD5Transform (UINT32 state[4], unsigned char block[64])

{

UINT32 a = state[0], b = state[1], c = state[2], d = state[3], x[16];

Decode (x, block, 64);

/* Round 1 */

FF (a, b, c, d, x[ 0], S11, 0xd76aa478); /* 1 */

FF (d, a, b, c, x[ 1], S12, 0xe8c7b756); /* 2 */

FF (c, d, a, b, x[ 2], S13, 0x242070db); /* 3 */

FF (b, c, d, a, x[ 3], S14, 0xc1bdceee); /* 4 */

FF (a, b, c, d, x[ 4], S11, 0xf57c0faf); /* 5 */

FF (d, a, b, c, x[ 5], S12, 0x4787c62a); /* 6 */

FF (c, d, a, b, x[ 6], S13, 0xa8304613); /* 7 */

FF (b, c, d, a, x[ 7], S14, 0xfd469501); /* 8 */

FF (a, b, c, d, x[ 8], S11, 0x698098d8); /* 9 */

FF (d, a, b, c, x[ 9], S12, 0x8b44f7af); /* 10 */

FF (c, d, a, b, x[10], S13, 0xffff5bb1); /* 11 */

FF (b, c, d, a, x[11], S14, 0x895cd7be); /* 12 */

FF (a, b, c, d, x[12], S11, 0x6b901122); /* 13 */

FF (d, a, b, c, x[13], S12, 0xfd987193); /* 14 */

FF (c, d, a, b, x[14], S13, 0xa679438e); /* 15 */

FF (b, c, d, a, x[15], S14, 0x49b40821); /* 16 */

/* Round 2 */

GG (a, b, c, d, x[ 1], S21, 0xf61e2562); /* 17 */

GG (d, a, b, c, x[ 6], S22, 0xc040b340); /* 18 */

GG (c, d, a, b, x[11], S23, 0x265e5a51); /* 19 */

GG (b, c, d, a, x[ 0], S24, 0xe9b6c7aa); /* 20 */

GG (a, b, c, d, x[ 5], S21, 0xd62f105d); /* 21 */

GG (d, a, b, c, x[10], S22, 0x2441453); /* 22 */

GG (c, d, a, b, x[15], S23, 0xd8a1e681); /* 23 */

GG (b, c, d, a, x[ 4], S24, 0xe7d3fbc8); /* 24 */

GG (a, b, c, d, x[ 9], S21, 0x21e1cde6); /* 25 */

GG (d, a, b, c, x[14], S22, 0xc33707d6); /* 26 */

GG (c, d, a, b, x[ 3], S23, 0xf4d50d87); /* 27 */

GG (b, c, d, a, x[ 8], S24, 0x455a14ed); /* 28 */

GG (a, b, c, d, x[13], S21, 0xa9e3e905); /* 29 */

GG (d, a, b, c, x[ 2], S22, 0xfcefa3f8); /* 30 */

GG (c, d, a, b, x[ 7], S23, 0x676f02d9); /* 31 */

GG (b, c, d, a, x[12], S24, 0x8d2a4c8a); /* 32 */

/* Round 3 */

HH (a, b, c, d, x[ 5], S31, 0xfffa3942); /* 33 */

HH (d, a, b, c, x[ 8], S32, 0x8771f681); /* 34 */

HH (c, d, a, b, x[11], S33, 0x6d9d6122); /* 35 */

HH (b, c, d, a, x[14], S34, 0xfde5380c); /* 36 */

HH (a, b, c, d, x[ 1], S31, 0xa4beea44); /* 37 */

HH (d, a, b, c, x[ 4], S32, 0x4bdecfa9); /* 38 */

HH (c, d, a, b, x[ 7], S33, 0xf6bb4b60); /* 39 */

HH (b, c, d, a, x[10], S34, 0xbebfbc70); /* 40 */

HH (a, b, c, d, x[13], S31, 0x289b7ec6); /* 41 */

HH (d, a, b, c, x[ 0], S32, 0xeaa127fa); /* 42 */

HH (c, d, a, b, x[ 3], S33, 0xd4ef3085); /* 43 */

HH (b, c, d, a, x[ 6], S34, 0x4881d05); /* 44 */

HH (a, b, c, d, x[ 9], S31, 0xd9d4d039); /* 45 */

HH (d, a, b, c, x[12], S32, 0xe6db99e5); /* 46 */

HH (c, d, a, b, x[15], S33, 0x1fa27cf8); /* 47 */

HH (b, c, d, a, x[ 2], S34, 0xc4ac5665); /* 48 */

/* Round 4 */

II (a, b, c, d, x[ 0], S41, 0xf4292244); /* 49 */

II (d, a, b, c, x[ 7], S42, 0x432aff97); /* 50 */

II (c, d, a, b, x[14], S43, 0xab9423a7); /* 51 */

II (b, c, d, a, x[ 5], S44, 0xfc93a039); /* 52 */

II (a, b, c, d, x[12], S41, 0x655b59c3); /* 53 */

II (d, a, b, c, x[ 3], S42, 0x8f0ccc92); /* 54 */

II (c, d, a, b, x[10], S43, 0xffeff47d); /* 55 */

II (b, c, d, a, x[ 1], S44, 0x85845dd1); /* 56 */

II (a, b, c, d, x[ 8], S41, 0x6fa87e4f); /* 57 */

II (d, a, b, c, x[15], S42, 0xfe2ce6e0); /* 58 */

II (c, d, a, b, x[ 6], S43, 0xa3014314); /* 59 */

II (b, c, d, a, x[13], S44, 0x4e0811a1); /* 60 */

II (a, b, c, d, x[ 4], S41, 0xf7537e82); /* 61 */

II (d, a, b, c, x[11], S42, 0xbd3af235); /* 62 */

II (c, d, a, b, x[ 2], S43, 0x2ad7d2bb); /* 63 */

II (b, c, d, a, x[ 9], S44, 0xeb86d391); /* 64 */

state[0] += a;

state[1] += b;

state[2] += c;

state[3] += d;

memset ((unsigned char *)x, 0, sizeof (x));

}

static void Encode (unsigned char *output, UINT32 *input, unsigned int len)

{

unsigned int i, j;

for (i = 0, j = 0; j len; i++, j += 4) {

output[j] = (unsigned char)(input[i] 0xff);

output[j+1] = (unsigned char)((input[i] 8) 0xff);

output[j+2] = (unsigned char)((input[i] 16) 0xff);

output[j+3] = (unsigned char)((input[i] 24) 0xff);

}

}

static void Decode (UINT32 *output, unsigned char *input, unsigned int len)

{

unsigned int i, j;

for (i = 0, j = 0; j len; i++, j += 4)

output[i] = ((UINT32)input[j]) | (((UINT32)input[j+1]) 8) |

(((UINT32)input[j+2]) 16) | (((UINT32)input[j+3]) 24);

}

--------------------------

就这两个文件。使用的时候把它们加入工程或者makefile,调用时包含md5.h即可,给个简单的例子,输入一个字符串然后计算它的md5值并输出,在VC6.0和GCC4.4下测试通过:

#include stdio.h

#include string.h

#include "md5.h"

int main ()

{

char tmp[128];

unsigned char digest[16];

MD5_CTX context;

scanf("%s",tmp);

MD5Init (context);

MD5Update (context, (unsigned char*)tmp, strlen(tmp));

MD5Final (digest,context);

printf("MD5Value:");

for(int i=0; i16; ++i)

{

printf("%02X",digest[i]);

}

printf("\n");

return 0;

}

求MD5加密算法的C语言源码

(转载) #include stdio.h #include stdlib.h #include memory.h #include time.h #include errno.h #include string.h #include sys/socket.h #include sys/types.h #include netinet/in.h #include arpa/inet.h #include netdb.h #include "../md5/md5.h" #define T1 0xd76aa478 #define T2 0xe8c7b756 #define T3 0x242070db #define T4 0xc1bdceee #define T5 0xf57c0faf #define T6 0x4787c62a #define T7 0xa8304613 #define T8 0xfd469501 #define T9 0x698098d8 #define T10 0x8b44f7af #define T11 0xffff5bb1 #define T12 0x895cd7be #define T13 0x6b901122 #define T14 0xfd987193 #define T15 0xa679438e #define T16 0x49b40821 #define T17 0xf61e2562 #define T18 0xc040b340 #define T19 0x265e5a51 #define T20 0xe9b6c7aa #define T21 0xd62f105d #define T22 0x02441453 #define T23 0xd8a1e681 #define T24 0xe7d3fbc8 #define T25 0x21e1cde6 #define T26 0xc33707d6 #define T27 0xf4d50d87 #define T28 0x455a14ed #define T29 0xa9e3e905 #define T30 0xfcefa3f8 #define T31 0x676f02d9 #define T32 0x8d2a4c8a #define T33 0xfffa3942 #define T34 0x8771f681 #define T35 0x6d9d6122 #define T36 0xfde5380c #define T37 0xa4beea44 #define T38 0x4bdecfa9 #define T39 0xf6bb4b60 #define T40 0xbebfbc70 #define T41 0x289b7ec6 #define T42 0xeaa127fa #define T43 0xd4ef3085 #define T44 0x04881d05 #define T45 0xd9d4d039 #define T46 0xe6db99e5 #define T47 0x1fa27cf8 #define T48 0xc4ac5665 #define T49 0xf4292244 #define T50 0x432aff97 #define T51 0xab9423a7 #define T52 0xfc93a039 #define T53 0x655b59c3 #define T54 0x8f0ccc92 #define T55 0xffeff47d #define T56 0x85845dd1 #define T57 0x6fa87e4f #define T58 0xfe2ce6e0 #define T59 0xa3014314 #define T60 0x4e0811a1 #define T61 0xf7537e82 #define T62 0xbd3af235 #define T63 0x2ad7d2bb #define T64 0xeb86d391 static void md5_process(md5_state_t *pms, const md5_byte_t *data /*[64]*/) { md5_word_t a = pms-abcd[0], b = pms-abcd[1], c = pms-abcd[2], d = pms-abcd[3]; md5_word_t t; #ifndef ARCH_IS_BIG_ENDIAN # define ARCH_IS_BIG_ENDIAN 1 /* slower, default implementation */ #endif #if ARCH_IS_BIG_ENDIAN /* * On big-endian machines, we must arrange the bytes in the right * order. (This also works on machines of unknown byte order.) */ md5_word_t X[16]; const md5_byte_t *xp = data; int i; for (i = 0; i 16; i, xp = 4) X[i] = xp[0] (xp[1] 8) (xp[2] 16) (xp[3] 24); #else /* !ARCH_IS_BIG_ENDIAN */ /* * On little-endian machines, we can process properly aligned data * without copying it. */ md5_word_t xbuf[16]; const md5_word_t *X; if (!((data - (const md5_byte_t *)0) 3)) { /* data are properly aligned */ X = (const md5_word_t *)data; } else { /* not aligned */ memcpy(xbuf, data, 64); X = xbuf; } #endif #define ROTATE_LEFT(x, n) (((x) (n)) | ((x) (32 - (n)))) /* Round 1. */ /* Let [abcd k s i] denote the operation a = b ((a F(b,c,d) X[k] T[i]) s). */ #define F(x, y, z) (((x) (y)) | (~(x) (z))) #define SET(a, b, c, d, k, s, Ti)\ t = a F(b,c,d) X[k] Ti;\ a = ROTATE_LEFT(t, s) b /* Do the following 16 operations. */ SET(a, b, c, d, 0, 7, T1); SET(d, a, b, c, 1, 12, T2); SET(c, d, a, b, 2, 17, T3); SET(b, c, d, a, 3, 22, T4); SET(a, b, c, d, 4, 7, T5); SET(d, a, b, c, 5, 12, T6); SET(c, d, a, b, 6, 17, T7); SET(b, c, d, a, 7, 22, T8); SET(a, b, c, d, 8, 7, T9); SET(d, a, b, c, 9, 12, T10); SET(c, d, a, b, 10, 17, T11); SET(b, c, d, a, 11, 22, T12); SET(a, b, c, d, 12, 7, T13); SET(d, a, b, c, 13, 12, T14); SET(c, d, a, b, 14, 17, T15); SET(b, c, d, a, 15, 22, T16); #undef SET /* Round 2. */ /* Let [abcd k s i] denote the operation a = b ((a G(b,c,d) X[k] T[i]) s). */ #define G(x, y, z) (((x) (z)) | ((y) ~(z))) #define SET(a, b, c, d, k, s, Ti)\ t = a G(b,c,d) X[k] Ti;\ a = ROTATE_LEFT(t, s) b /* Do the following 16 operations. */ SET(a, b, c, d, 1, 5, T17); SET(d, a, b, c, 6, 9, T18); SET(c, d, a, b, 11, 14, T19); SET(b, c, d, a, 0, 20, T20); SET(a, b, c, d, 5, 5, T21); SET(d, a, b, c, 10, 9, T22); SET(c, d, a, b, 15, 14, T23); SET(b, c, d, a, 4, 20, T24); SET(a, b, c, d, 9, 5, T25); SET(d, a, b, c, 14, 9, T26); SET(c, d, a, b, 3, 14, T27); SET(b, c, d, a, 8, 20, T28); SET(a, b, c, d, 13, 5, T29); SET(d, a, b, c, 2, 9, T30); SET(c, d, a, b, 7, 14, T31); SET(b, c, d, a, 12, 20, T32); #undef SET

刷机包md5码 是什么

MessageDigestAlgorithmMD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护。md5典型应用是对一段信息(Message)产生信息摘要(Message-Digest),以防止被篡改。比如你的刷机包md5码,网站会提供一个源码,你下载完成后使用md5工具对你的下载包进行校验,检查是否跟网站上提供的码对得上,如果对不上可以鉴定为这个刷机包被人恶意修改过,一般黑客喜欢在这种东西当中植入病毒和木马

求32位MD5加密c语言源码

#includestdio.h

#includestring.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) (x24)|((x8)0xff0000)|((x8)0xff00)|(x24) //将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))

unsigned A,B,C,D,a,b,c,d,i,len,flen[2],x[16]; //i临时变量,len文件长,flen[2]为64位二进制表示的文件初始长度

char filename[200]; //文件名

FILE *fp;

void md5(){ //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;

}

main(){

while(1){

printf("Input file:");

gets(filename); //用get函数,避免scanf以空格分割数据,

if (filename[0]==34) filename[strlen(filename)-1]=0,strcpy(filename,filename+1); //支持文件拖曳,但会多出双引号,这里是处理多余的双引号

if (!strcmp(filename,"exit")) exit(0); //输入exit退出

if (!(fp=fopen(filename,"rb"))) {printf("Can not open this file!\n");continue;} //以二进制打开文件

fseek(fp, 0, SEEK_END); //文件指针转到文件末尾

if((len=ftell(fp))==-1) {printf("Sorry! Can not calculate files which larger than 2 GB!\n");fclose(fp);continue;} //ftell函数返回long,最大为2GB,超出返回-1

rewind(fp); //文件指针复位到文件头

A=0x67452301,B=0xefcdab89,C=0x98badcfe,D=0x10325476; //初始化链接变量

flen[1]=len/0x20000000; //flen单位是bit

flen[0]=(len%0x20000000)*8;

memset(x,0,64); //初始化x数组为0

fread(x,4,16,fp); //以4字节为一组,读取16组数据

for(i=0;ilen/64;i++){ //循环运算直至文件结束

md5();

memset(x,0,64);

fread(x,4,16,fp);

}

((char*)x)[len%64]=128; //文件结束补1,补0操作,128二进制即10000000

if(len%6455) md5(),memset(x,0,64);

memcpy(x+14,flen,8); //文件末尾加入原文件的bit长度

md5();

fclose(fp);

printf("MD5 Code:%08x%08x%08x%08x\n",PP(A),PP(B),PP(C),PP(D)); //高低位逆反输出

}

}