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

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

?? md5.cpp

?? 一個簡單的MD5加密封裝類 !喜歡的朋友可以下來
?? CPP
字號:
/******************************************************************************
*  Copyright (C) 2000 by Robert Hubley.                                      *
*  All rights reserved.                                                      *
*                                                                            *
*  This software is provided ``AS IS'' and any express or implied            *
*  warranties, including, but not limited to, the implied warranties of      *
*  merchantability and fitness for a particular purpose, are disclaimed.     *
*  In no event shall the authors be liable for any direct, indirect,         *
*  incidental, special, exemplary, or consequential damages (including, but  *
*  not limited to, procurement of substitute goods or services; loss of use, *
*  data, or profits; or business interruption) however caused and on any     *
*  theory of liability, whether in contract, strict liability, or tort       *
*  (including negligence or otherwise) arising in any way out of the use of  *
*  this software, even if advised of the possibility of such damage.         *
*                                                                            *
******************************************************************************

	MD5C.C - RSA Data Security, Inc., MD5 message-digest algorithm

	Port to Win32 DLL by Robert Hubley 1/5/2000

	Original Copyright:

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

#include "md5.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

/* 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) + (unsigned long int)(ac); \
	(a) = ROTATE_LEFT ((a), (s)); \
	(a) += (b); \
	}
#define GG(a, b, c, d, x, s, ac) { \
	(a) += G ((b), (c), (d)) + (x) + (unsigned long int)(ac); \
	(a) = ROTATE_LEFT ((a), (s)); \
	(a) += (b); \
	}
#define HH(a, b, c, d, x, s, ac) { \
	(a) += H ((b), (c), (d)) + (x) + (unsigned long int)(ac); \
	(a) = ROTATE_LEFT ((a), (s)); \
	(a) += (b); \
	}
#define II(a, b, c, d, x, s, ac) { \
	(a) += I ((b), (c), (d)) + (x) + (unsigned long int)(ac); \
	(a) = ROTATE_LEFT ((a), (s)); \
	(a) += (b); \
	}


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

MD5_CTX::MD5_CTX()
{
	MD5Init ();
}

MD5_CTX::~MD5_CTX()
{
}

void MD5_CTX::MD5Init ()
{
	this->count[0] = this->count[1] = 0;
	/* Load magic initialization constants.*/
	this->state[0] = 0x67452301;
	this->state[1] = 0xefcdab89;
	this->state[2] = 0x98badcfe;
	this->state[3] = 0x10325476;
	/* Add by Liguangyi */
	MD5_memset(PADDING, 0, sizeof(PADDING));
	*PADDING=0x80;
	//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	};
}

/* MD5 block update operation. Continues an MD5 message-digest
operation, processing another message block, and updating the
context.
*/
void MD5_CTX::MD5Update (unsigned char *input,unsigned int inputLen)
{
	unsigned int i, index, partLen;
	
	/* Compute number of bytes mod 64 */
	index = (unsigned int)((this->count[0] >> 3) & 0x3F);
	
	/* Update number of bits */
	if ((this->count[0] += ((unsigned long int)inputLen << 3))
		< ((unsigned long int)inputLen << 3))
		this->count[1]++;
	this->count[1] += ((unsigned long int)inputLen >> 29);
	
	partLen = 64 - index;
	
	/* Transform as many times as possible.
	*/
	if (inputLen >= partLen) {
		MD5_memcpy((unsigned char*)&this->buffer[index], 
			(unsigned char*)input, partLen);
		MD5Transform (this->state, this->buffer);
		
		for (i = partLen; i + 63 < inputLen; i += 64)
			MD5Transform (this->state, &input[i]);
		
		index = 0;
	}
	else
		i = 0;
	
	/* Buffer remaining input */
	MD5_memcpy ((unsigned char*)&this->buffer[index], (unsigned char*)&input[i], inputLen-i);
}

/* MD5 finalization. Ends an MD5 message-digest operation, writing the
the message digest and zeroizing the context.
*/
void MD5_CTX::MD5Final (unsigned char digest[16])
{
	unsigned char bits[8];
	unsigned int index, padLen;
	
	/* Save number of bits */
	Encode (bits, this->count, 8);
	
	/* Pad out to 56 mod 64.
	*/
	index = (unsigned int)((this->count[0] >> 3) & 0x3f);
	padLen = (index < 56) ? (56 - index) : (120 - index);
	MD5Update ( PADDING, padLen);
	
	/* Append length (before padding) */
	MD5Update (bits, 8);
	/* Store state in digest */
	Encode (digest, this->state, 16);
	
	/* Zeroize sensitive information.
	*/
	MD5_memset ((unsigned char*)this, 0, sizeof (*this));
	this->MD5Init();
}

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

/* Encodes input (unsigned long int) into output (unsigned char). Assumes len is
a multiple of 4.
*/
void MD5_CTX::Encode (unsigned char *output, unsigned long int *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 (unsigned long int). Assumes len is
a multiple of 4.
*/
void MD5_CTX::Decode (unsigned long int *output, unsigned char *input, unsigned int len)
{
	unsigned int i, j;
	
	for (i = 0, j = 0; j < len; i++, j += 4)
		output[i] = ((unsigned long int)input[j]) | (((unsigned long int)input[j+1]) << 8) |
		(((unsigned long int)input[j+2]) << 16) | (((unsigned long int)input[j+3]) << 24);
}

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

void MD5_CTX::MD5_memcpy (unsigned char* output, unsigned char* 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.
*/
void MD5_CTX::MD5_memset (unsigned char* 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一区二区三区免费野_久草精品视频
日产精品久久久久久久性色| 色哟哟一区二区三区| 成人福利视频在线看| 色网站国产精品| 欧美成人午夜电影| 亚洲免费在线看| 国产精品一区二区久久精品爱涩| 色猫猫国产区一区二在线视频| 精品国产99国产精品| 亚洲在线观看免费视频| 国产成人免费在线视频| 欧美猛男男办公室激情| 亚洲视频一二三区| 国产一区二区三区黄视频 | 91丨porny丨户外露出| 欧美r级在线观看| 性久久久久久久| 一本一道久久a久久精品 | 极品少妇xxxx偷拍精品少妇| 色婷婷av久久久久久久| 国产精品天干天干在观线| 久色婷婷小香蕉久久| 欧美日韩在线免费视频| 中文字幕一区二区三区不卡 | 国产成人免费在线观看| 精品国产一区a| 久久精品免费观看| 欧美日韩一区二区三区免费看| 亚洲视频每日更新| k8久久久一区二区三区| 久久婷婷一区二区三区| 韩国理伦片一区二区三区在线播放| 欧美日韩国产一级片| 亚洲成人自拍网| 欧美日韩国产综合一区二区三区| 亚洲视频1区2区| 色8久久精品久久久久久蜜| 亚洲天堂2016| 91成人在线免费观看| 亚洲女人****多毛耸耸8| 91精彩视频在线| 亚洲永久精品国产| 在线不卡免费欧美| 蜜桃久久久久久| 精品成人免费观看| 国产99精品国产| 国产精品动漫网站| 色偷偷久久一区二区三区| 午夜久久久影院| 日韩一级成人av| 精品亚洲免费视频| 国产精品三级av在线播放| 成人av免费在线播放| 樱花影视一区二区| 欧美日韩国产色站一区二区三区| 三级欧美在线一区| 久久久亚洲高清| 91视频在线观看| 天天影视涩香欲综合网| 日韩精品一区国产麻豆| 国产精品12区| 亚洲国产成人av网| 精品伦理精品一区| 91啪亚洲精品| 久久精品国产第一区二区三区| 久久久久久**毛片大全| 色女孩综合影院| 日韩电影一区二区三区四区| 久久精品夜夜夜夜久久| 色老汉av一区二区三区| 久久精品免费看| 一区二区三区色| 精品99久久久久久| 色哟哟欧美精品| 国产一区二区视频在线播放| 日韩美女精品在线| 日韩免费高清电影| 91浏览器打开| 美女看a上一区| 一区二区在线观看视频在线观看| 日韩一区二区免费电影| 色婷婷久久综合| 激情成人综合网| 亚洲风情在线资源站| 国产视频一区二区三区在线观看| 在线亚洲人成电影网站色www| 麻豆精品在线看| 亚洲一区二区欧美| 欧美国产综合色视频| 日韩欧美你懂的| 欧美日韩一区二区三区高清| jlzzjlzz亚洲日本少妇| 精品亚洲成a人| 水野朝阳av一区二区三区| 中文字幕在线免费不卡| 久久久久国产精品免费免费搜索| 欧美日韩久久不卡| 色综合网站在线| 不卡欧美aaaaa| 国产精品亚洲人在线观看| 日韩中文欧美在线| 亚洲成av人片观看| 亚洲最快最全在线视频| 综合分类小说区另类春色亚洲小说欧美| 精品国产乱码久久久久久1区2区 | 777午夜精品免费视频| 91在线观看美女| 国产**成人网毛片九色 | 日韩中文字幕区一区有砖一区| 亚洲视频一二区| 国产精品福利影院| 中文字幕精品一区| 亚洲欧洲日韩av| 国产精品国产三级国产aⅴ原创 | 国产精品久久久久久久久搜平片 | 国产专区综合网| 久久国产精品一区二区| 日韩av不卡一区二区| 日韩国产精品久久| 日产欧产美韩系列久久99| 日韩在线a电影| 久久精品国产第一区二区三区| 麻豆久久久久久| 国产精品亚洲一区二区三区妖精| 国产一区二区毛片| 成人免费看片app下载| av电影在线观看完整版一区二区| 国产91精品在线观看| 成人a区在线观看| 色综合夜色一区| 精品视频1区2区3区| 日韩午夜小视频| 26uuuu精品一区二区| 国产亚洲欧美日韩俺去了| 中日韩免费视频中文字幕| 亚洲欧美区自拍先锋| 亚洲高清不卡在线观看| 精品一区二区三区在线观看国产| 国产一区视频在线看| 成人h精品动漫一区二区三区| 色94色欧美sute亚洲13| 91精品国产综合久久久蜜臀图片| 精品少妇一区二区三区| 中文字幕的久久| 午夜影院久久久| 精品综合久久久久久8888| 成人av集中营| 在线不卡免费av| 久久精子c满五个校花| 亚洲免费观看高清完整版在线| 奇米一区二区三区| fc2成人免费人成在线观看播放| 在线免费不卡电影| 久久综合色播五月| 一区二区三区在线观看动漫| 秋霞影院一区二区| 99久久久久久| 日韩一区二区影院| 亚洲欧美偷拍三级| 精品在线免费视频| 在线一区二区观看| 日本一区二区三区电影| 亚洲国产精品久久人人爱| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 在线中文字幕不卡| 国产亚洲短视频| 日日嗨av一区二区三区四区| 国产91丝袜在线播放九色| 欧美日韩一区二区三区四区五区| 久久精品免费在线观看| 午夜国产精品一区| 99麻豆久久久国产精品免费 | 欧美色爱综合网| 国产欧美日韩综合精品一区二区| 亚洲成人777| 成人手机在线视频| 日韩女优毛片在线| 视频一区二区中文字幕| 91啦中文在线观看| 中文字幕一区二区三区在线不卡| 久草这里只有精品视频| 91精品综合久久久久久| 亚洲精品免费播放| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 国产午夜精品美女毛片视频| 午夜精品视频一区| 在线免费观看日韩欧美| 中文字幕一区二区在线观看| 国产大陆a不卡| 久久综合久久鬼色| 久久成人羞羞网站| 日韩一区二区三区视频在线观看| 亚洲一区二区欧美激情| 在线视频观看一区| 一区二区三区四区激情| 在线中文字幕不卡| 一区二区三区精品视频| 色吧成人激情小说| 一区二区在线观看免费| 欧美在线视频全部完|