亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? md5.c

?? 采用CAST-256位加密的Back Orifice 2000插件源代碼
?? C
字號:
/* 
 MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm 

 Copyright (C) 1991-2, RSA Data Security, Inc. Created 1991. All
 rights reserved.
  
 License to copy and use this software is granted provided that it
 is identified as the "RSA Data Security, Inc. MD5 Message-Digest
 Algorithm" in all material mentioning or referencing this software
 or this function.
	
 License is also granted to make and use derivative works provided
 that such works are identified as "derived from the RSA Data
 Security, Inc. MD5 Message-Digest Algorithm" in all material
 mentioning or referencing the derived work.
	  
 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.
*/

/* Some modifications made by Daniel Roethlisberger <admin@roe.ch> */

#include "global.h"
#include "md5.h"
#include <memory.h>

/* 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

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); \
	}

/* MD5 initialization. Begins an MD5 operation, writing a new context.
*/
void MD5Init (context)
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 (context, input, inputLen)
MD5_CTX *context;                                        /* context */
unsigned char *input;                                /* input block */
unsigned int inputLen;                     /* 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) {
		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 */
	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 (digest, context)
unsigned char digest[16];                         /* message digest */
MD5_CTX *context;                                       /* 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, PADDING, padLen);
	
	/* Append length (before padding) */
	MD5Update (context, bits, 8);
			
	/* Store state in digest */
	Encode (digest, context->state, 16);
	
	/* Zeroize sensitive information. */
	memset((POINTER)context, 0, sizeof (*context));
}

/* MD5 basic transformation. Transforms state based on block.
*/
static void MD5Transform (state, block)
UINT4 state[4];
unsigned char block[64];
{
	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. */
	memset((POINTER)x, 0, sizeof(x));
}

/* Encodes input (UINT4) into output (unsigned char). Assumes len is
a multiple of 4.
*/
static void Encode (output, input, len)
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 (output, input, len)
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 (output, input, len)
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 (output, value, len)
POINTER output;
int value;
unsigned int len;
{
	unsigned int i;
	
	for (i = 0; i < len; i++)
		((char *)output)[i] = (char)value;
}

/**/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人激情动漫在线观看| 久久婷婷色综合| 欧美精品一区二| 自拍偷在线精品自拍偷无码专区| 午夜精品福利一区二区蜜股av| 国产激情视频一区二区在线观看| 欧美区一区二区三区| 国产精品麻豆视频| 欧美日韩一本到| 久久久噜噜噜久久中文字幕色伊伊 | 99久久久免费精品国产一区二区| 91麻豆精品国产自产在线观看一区| 国产精品久久久久一区二区三区| 激情综合网av| 日韩亚洲欧美综合| 婷婷综合另类小说色区| 色噜噜久久综合| 日韩一区欧美一区| 从欧美一区二区三区| 精品久久人人做人人爰| 三级久久三级久久| 精品视频一区 二区 三区| 亚洲欧美日韩一区| 91女厕偷拍女厕偷拍高清| 欧美激情一区二区三区四区| 黄色资源网久久资源365| 9191精品国产综合久久久久久| 亚洲午夜精品一区二区三区他趣| 91麻豆国产福利在线观看| 国产精品麻豆欧美日韩ww| 波多野结衣中文字幕一区| 欧美国产在线观看| 成人国产精品免费观看| 国产精品视频在线看| 成人黄色在线网站| 亚洲色欲色欲www| 91香蕉视频黄| 一区二区免费看| 欧美日韩一区二区三区四区| 亚洲国产视频网站| 91精品国产欧美一区二区成人| 日韩不卡免费视频| 26uuu国产一区二区三区| 国产精品一二一区| 日韩美女视频19| 在线观看免费亚洲| 日韩国产精品久久| 久久久久成人黄色影片| 成人精品免费视频| 伊人开心综合网| 欧美精品日韩综合在线| 久久精品国产免费| 中文字幕不卡三区| 欧美三级蜜桃2在线观看| 午夜精品久久久久久久99樱桃| 日韩精品一区二区三区三区免费 | 在线观看国产精品网站| 日韩主播视频在线| 国产亚洲一本大道中文在线| 91在线播放网址| 日韩精品一二三四| 国产色爱av资源综合区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 性欧美大战久久久久久久久| 日韩小视频在线观看专区| 国产传媒久久文化传媒| 洋洋av久久久久久久一区| 日韩亚洲欧美高清| 97超碰欧美中文字幕| 日韩专区在线视频| 亚洲特黄一级片| 日韩欧美第一区| 91麻豆成人久久精品二区三区| 日韩va亚洲va欧美va久久| 国产精品女主播av| 欧美一区二区三区播放老司机| 成人中文字幕电影| 麻豆精品国产91久久久久久| 国产精品乱人伦| 日韩一区二区三区四区| 91污在线观看| 国产精品一线二线三线| 午夜免费久久看| 中文字幕在线一区免费| 日韩美一区二区三区| 日本韩国欧美一区二区三区| 国产乱人伦偷精品视频免下载| 一区二区不卡在线播放 | 欧美激情一区二区三区| 在线免费视频一区二区| 粉嫩在线一区二区三区视频| 婷婷成人综合网| 亚洲欧美日韩国产手机在线| 国产天堂亚洲国产碰碰| 日韩精品一区二| 91精品久久久久久久99蜜桃| 在线影院国内精品| 波多野洁衣一区| 国产成人精品亚洲777人妖| 麻豆视频一区二区| 亚洲第一在线综合网站| 亚洲欧美另类小说| 国产精品美女久久久久aⅴ国产馆| 精品处破学生在线二十三| 69堂国产成人免费视频| 欧美日韩免费电影| 欧美日韩中字一区| 欧洲一区二区av| 91成人网在线| 欧美午夜一区二区| 欧美日韩精品一区二区三区四区| 日本精品一区二区三区高清 | 精品一区二区三区免费播放| 五月天激情综合| 亚洲国产一区二区三区 | 激情图片小说一区| 久久er精品视频| 久久99精品国产91久久来源| 免费成人性网站| 另类小说欧美激情| 国产一区二区三区黄视频 | 91视频.com| 欧美在线观看你懂的| 欧美视频一区二| 91精品国产综合久久久久| 欧美一区二区成人6969| 日韩女优毛片在线| 国产午夜精品久久| √…a在线天堂一区| 亚洲精品乱码久久久久久 | 美日韩黄色大片| 国产美女在线精品| 成人免费视频视频在线观看免费| 成人污视频在线观看| 色诱亚洲精品久久久久久| 欧美婷婷六月丁香综合色| 欧美疯狂性受xxxxx喷水图片| 精品国一区二区三区| 久久精品一区二区| 一区二区三区在线观看视频| 性做久久久久久免费观看欧美| 麻豆国产精品一区二区三区| 国产成人高清视频| 在线观看三级视频欧美| 欧美一级精品在线| 国产精品护士白丝一区av| 一区二区三区中文在线观看| 日韩国产欧美一区二区三区| 粗大黑人巨茎大战欧美成人| 日本丰满少妇一区二区三区| 欧美va亚洲va在线观看蝴蝶网| 国产精品剧情在线亚洲| 午夜精品影院在线观看| 国产黄色成人av| 欧美精品在线观看播放| 欧美高清在线视频| 午夜激情久久久| 成人精品国产一区二区4080| 欧美日韩一区二区三区在线看| 精品sm捆绑视频| 夜夜爽夜夜爽精品视频| 国产成人免费av在线| 欧美另类久久久品| 亚洲视频一二三区| 狠狠狠色丁香婷婷综合激情| 欧美性猛交xxxx黑人交| 日本一区二区视频在线| 日韩精品色哟哟| 97aⅴ精品视频一二三区| 精品国产免费人成在线观看| 亚洲国产精品久久久久婷婷884| 国产成人精品aa毛片| 日韩情涩欧美日韩视频| 亚洲午夜久久久久久久久久久| 国产麻豆精品在线| 欧美一级理论片| 亚洲成va人在线观看| 91免费精品国自产拍在线不卡| 精品国产髙清在线看国产毛片 | 亚洲一区二区成人在线观看| 国产高清视频一区| 欧美xxxxx牲另类人与| 午夜欧美一区二区三区在线播放| 99在线热播精品免费| 国产三区在线成人av| 国产精品中文字幕一区二区三区| 日韩欧美国产综合在线一区二区三区| 亚洲天堂2016| 91在线一区二区| 亚洲欧洲精品一区二区三区不卡| 国产精品一线二线三线| 伊人夜夜躁av伊人久久| 91免费在线看| 亚洲人成网站色在线观看| 成人h动漫精品| 国产日韩欧美精品综合| 春色校园综合激情亚洲| 中日韩av电影| zzijzzij亚洲日本少妇熟睡| 欧美激情资源网|