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

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

?? md5checksum.cpp

?? 一個簡單的視頻會議VC++MFC工程文件
?? CPP
字號:



#include "stdafx.h"
#include "MD5Checksum.h"
#include "MD5ChecksumDefines.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif



CString CMD5Checksum::GetMD5(BYTE* pBuf, UINT nLength)
{
	
	CMD5Checksum MD5Checksum;
	MD5Checksum.Update( pBuf, nLength );
	return MD5Checksum.Final();
}



DWORD CMD5Checksum::RotateLeft(DWORD x, int n)
{
	
	return (x << n) | (x >> (32-n));
}



void CMD5Checksum::FF( DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T)
{
	DWORD F = (B & C) | (~B & D);
	A += F + X + T;
	A = RotateLeft(A, S);
	A += B;
}



void CMD5Checksum::GG( DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T)
{
	DWORD G = (B & D) | (C & ~D);
	A += G + X + T;
	A = RotateLeft(A, S);
	A += B;
}



void CMD5Checksum::HH( DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T)
{
	DWORD H = (B ^ C ^ D);
	A += H + X + T;
	A = RotateLeft(A, S);
	A += B;
}



void CMD5Checksum::II( DWORD& A, DWORD B, DWORD C, DWORD D, DWORD X, DWORD S, DWORD T)
{
	DWORD I = (C ^ (B | ~D));
	A += I + X + T;
	A = RotateLeft(A, S);
	A += B;
}



void CMD5Checksum::ByteToDWord(DWORD* Output, BYTE* Input, UINT nLength)
{

	UINT i=0;	//index to Output array
	UINT j=0;	//index to Input array

	//transfer the data by shifting and copying
	for ( ; j < nLength; i++, j += 4)
	{
		Output[i] = (ULONG)Input[j]			| 
					(ULONG)Input[j+1] << 8	| 
					(ULONG)Input[j+2] << 16 | 
					(ULONG)Input[j+3] << 24;
	}
}

void CMD5Checksum::Transform(BYTE Block[])
{
	//initialise local data with current checksum
	ULONG a = m_lMD5[0];
	ULONG b = m_lMD5[1];
	ULONG c = m_lMD5[2];
	ULONG d = m_lMD5[3];

	//copy BYTES from input 'Block' to an array of ULONGS 'X'
	ULONG X[16];
	ByteToDWord( X, Block, 64 );

	//Perform Round 1 of the transformation
	FF (a, b, c, d, X[ 0], MD5_S11, MD5_T01); 
	FF (d, a, b, c, X[ 1], MD5_S12, MD5_T02); 
	FF (c, d, a, b, X[ 2], MD5_S13, MD5_T03); 
	FF (b, c, d, a, X[ 3], MD5_S14, MD5_T04); 
	FF (a, b, c, d, X[ 4], MD5_S11, MD5_T05); 
	FF (d, a, b, c, X[ 5], MD5_S12, MD5_T06); 
	FF (c, d, a, b, X[ 6], MD5_S13, MD5_T07); 
	FF (b, c, d, a, X[ 7], MD5_S14, MD5_T08); 
	FF (a, b, c, d, X[ 8], MD5_S11, MD5_T09); 
	FF (d, a, b, c, X[ 9], MD5_S12, MD5_T10); 
	FF (c, d, a, b, X[10], MD5_S13, MD5_T11); 
	FF (b, c, d, a, X[11], MD5_S14, MD5_T12); 
	FF (a, b, c, d, X[12], MD5_S11, MD5_T13); 
	FF (d, a, b, c, X[13], MD5_S12, MD5_T14); 
	FF (c, d, a, b, X[14], MD5_S13, MD5_T15); 
	FF (b, c, d, a, X[15], MD5_S14, MD5_T16); 

	//Perform Round 2 of the transformation
	GG (a, b, c, d, X[ 1], MD5_S21, MD5_T17); 
	GG (d, a, b, c, X[ 6], MD5_S22, MD5_T18); 
	GG (c, d, a, b, X[11], MD5_S23, MD5_T19); 
	GG (b, c, d, a, X[ 0], MD5_S24, MD5_T20); 
	GG (a, b, c, d, X[ 5], MD5_S21, MD5_T21); 
	GG (d, a, b, c, X[10], MD5_S22, MD5_T22); 
	GG (c, d, a, b, X[15], MD5_S23, MD5_T23); 
	GG (b, c, d, a, X[ 4], MD5_S24, MD5_T24); 
	GG (a, b, c, d, X[ 9], MD5_S21, MD5_T25); 
	GG (d, a, b, c, X[14], MD5_S22, MD5_T26); 
	GG (c, d, a, b, X[ 3], MD5_S23, MD5_T27); 
	GG (b, c, d, a, X[ 8], MD5_S24, MD5_T28); 
	GG (a, b, c, d, X[13], MD5_S21, MD5_T29); 
	GG (d, a, b, c, X[ 2], MD5_S22, MD5_T30); 
	GG (c, d, a, b, X[ 7], MD5_S23, MD5_T31); 
	GG (b, c, d, a, X[12], MD5_S24, MD5_T32); 

	//Perform Round 3 of the transformation
	HH (a, b, c, d, X[ 5], MD5_S31, MD5_T33); 
	HH (d, a, b, c, X[ 8], MD5_S32, MD5_T34); 
	HH (c, d, a, b, X[11], MD5_S33, MD5_T35); 
	HH (b, c, d, a, X[14], MD5_S34, MD5_T36); 
	HH (a, b, c, d, X[ 1], MD5_S31, MD5_T37); 
	HH (d, a, b, c, X[ 4], MD5_S32, MD5_T38); 
	HH (c, d, a, b, X[ 7], MD5_S33, MD5_T39); 
	HH (b, c, d, a, X[10], MD5_S34, MD5_T40); 
	HH (a, b, c, d, X[13], MD5_S31, MD5_T41); 
	HH (d, a, b, c, X[ 0], MD5_S32, MD5_T42); 
	HH (c, d, a, b, X[ 3], MD5_S33, MD5_T43); 
	HH (b, c, d, a, X[ 6], MD5_S34, MD5_T44); 
	HH (a, b, c, d, X[ 9], MD5_S31, MD5_T45); 
	HH (d, a, b, c, X[12], MD5_S32, MD5_T46); 
	HH (c, d, a, b, X[15], MD5_S33, MD5_T47); 
	HH (b, c, d, a, X[ 2], MD5_S34, MD5_T48); 

	//Perform Round 4 of the transformation
	II (a, b, c, d, X[ 0], MD5_S41, MD5_T49); 
	II (d, a, b, c, X[ 7], MD5_S42, MD5_T50); 
	II (c, d, a, b, X[14], MD5_S43, MD5_T51); 
	II (b, c, d, a, X[ 5], MD5_S44, MD5_T52); 
	II (a, b, c, d, X[12], MD5_S41, MD5_T53); 
	II (d, a, b, c, X[ 3], MD5_S42, MD5_T54); 
	II (c, d, a, b, X[10], MD5_S43, MD5_T55); 
	II (b, c, d, a, X[ 1], MD5_S44, MD5_T56); 
	II (a, b, c, d, X[ 8], MD5_S41, MD5_T57); 
	II (d, a, b, c, X[15], MD5_S42, MD5_T58); 
	II (c, d, a, b, X[ 6], MD5_S43, MD5_T59); 
	II (b, c, d, a, X[13], MD5_S44, MD5_T60); 
	II (a, b, c, d, X[ 4], MD5_S41, MD5_T61); 
	II (d, a, b, c, X[11], MD5_S42, MD5_T62); 
	II (c, d, a, b, X[ 2], MD5_S43, MD5_T63); 
	II (b, c, d, a, X[ 9], MD5_S44, MD5_T64); 

	//add the transformed values to the current checksum
	m_lMD5[0] += a;
	m_lMD5[1] += b;
	m_lMD5[2] += c;
	m_lMD5[3] += d;
}


/*****************************************************************************************
CONSTRUCTOR:	CMD5Checksum
DESCRIPTION:	Initialises member data
ARGUMENTS:		None
NOTES:			None
*****************************************************************************************/
CMD5Checksum::CMD5Checksum()
{
	// zero members
	memset( m_lpszBuffer, 0, 64 );
	m_nCount[0] = m_nCount[1] = 0;

	// Load magic state initialization constants
	m_lMD5[0] = MD5_INIT_STATE_0;
	m_lMD5[1] = MD5_INIT_STATE_1;
	m_lMD5[2] = MD5_INIT_STATE_2;
	m_lMD5[3] = MD5_INIT_STATE_3;
}


void CMD5Checksum::DWordToByte(BYTE* Output, DWORD* Input, UINT nLength )
{
	//entry invariants
//	ASSERT( nLength % 4 == 0 );
//	ASSERT( AfxIsValidAddress(Output, nLength, TRUE) );
//	ASSERT( AfxIsValidAddress(Input, nLength/4, FALSE) );

	//transfer the data by shifting and copying
	UINT i = 0;
	UINT j = 0;
	for ( ; j < nLength; i++, j += 4) 
	{
		Output[j] =   (UCHAR)(Input[i] & 0xff);
		Output[j+1] = (UCHAR)((Input[i] >> 8) & 0xff);
		Output[j+2] = (UCHAR)((Input[i] >> 16) & 0xff);
		Output[j+3] = (UCHAR)((Input[i] >> 24) & 0xff);
	}
}



CString CMD5Checksum::Final()
{
	//Save number of bits
	BYTE Bits[8];
	DWordToByte( Bits, m_nCount, 8 );

	//Pad out to 56 mod 64.
	UINT nIndex = (UINT)((m_nCount[0] >> 3) & 0x3f);
	UINT nPadLen = (nIndex < 56) ? (56 - nIndex) : (120 - nIndex);
	Update( PADDING, nPadLen );

	//Append length (before padding)
	Update( Bits, 8 );

	//Store final state in 'lpszMD5'
	const int nMD5Size = 16;
	unsigned char lpszMD5[ nMD5Size ];
	DWordToByte( lpszMD5, m_lMD5, nMD5Size );

	//Convert the hexadecimal checksum to a CString
	CString strMD5;
	for ( int i=0; i < nMD5Size; i++) 
	{
		CString Str;
		if (lpszMD5[i] == 0) {
			Str = CString("00");
		}
		else if (lpszMD5[i] <= 15) 	{
			Str.Format("0%x",lpszMD5[i]);
		}
		else {
			Str.Format("%x",lpszMD5[i]);
		}

//		ASSERT( Str.GetLength() == 2 );
		strMD5 += Str;
	}
//	ASSERT( strMD5.GetLength() == 32 );
	return strMD5;
}



void CMD5Checksum::Update( BYTE* Input,	ULONG nInputLen )
{
	//Compute number of bytes mod 64
	UINT nIndex = (UINT)((m_nCount[0] >> 3) & 0x3F);

	//Update number of bits
	if ( ( m_nCount[0] += nInputLen << 3 )  <  ( nInputLen << 3) )
	{
		m_nCount[1]++;
	}
	m_nCount[1] += (nInputLen >> 29);

	//Transform as many times as possible.
	UINT i=0;		
	UINT nPartLen = 64 - nIndex;
	if (nInputLen >= nPartLen) 	
	{
		memcpy( &m_lpszBuffer[nIndex], Input, nPartLen );
		Transform( m_lpszBuffer );
		for (i = nPartLen; i + 63 < nInputLen; i += 64) 
		{
			Transform( &Input[i] );
		}
		nIndex = 0;
	} 
	else 
	{
		i = 0;
	}

	// Buffer remaining input
	memcpy( &m_lpszBuffer[nIndex], &Input[i], nInputLen-i);
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合色天天久久综合图片| 一区二区三区中文字幕精品精品| 亚洲免费大片在线观看| 日本一区二区三区久久久久久久久不| av动漫一区二区| 国产三级欧美三级| 久久精品国产网站| 欧美一级在线观看| 免费欧美在线视频| 日韩亚洲欧美成人一区| 天天操天天综合网| 欧美日韩不卡视频| 亚洲午夜一区二区| 欧美日本国产一区| 美日韩一区二区| 久久久久久久综合日本| 精品一区二区免费| 久久久精品免费免费| 成人激情小说网站| 亚洲一区二区免费视频| 欧美一区二区在线播放| 国产揄拍国内精品对白| 国产日韩三级在线| 成人免费黄色大片| 亚洲网友自拍偷拍| 精品国产一区二区三区久久久蜜月 | 91蜜桃网址入口| 亚洲成人免费电影| 久久久国产精品午夜一区ai换脸| 岛国av在线一区| 亚洲国产另类精品专区| 国产亚洲精品超碰| 欧美专区日韩专区| www.亚洲免费av| 免费视频一区二区| 中文字幕一区二区5566日韩| 在线欧美日韩精品| 美女任你摸久久| 国产精品久久一卡二卡| 91精品国产福利| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 久久香蕉国产线看观看99| 91成人免费电影| 成人av手机在线观看| 另类综合日韩欧美亚洲| 亚洲精品网站在线观看| 国产欧美日韩精品a在线观看| 日韩欧美成人激情| 欧美日本一区二区三区| 99久久久久久| 91在线精品一区二区| 波波电影院一区二区三区| 国产一区二区网址| 另类欧美日韩国产在线| 久久综合色综合88| 国产成人一级电影| 天天亚洲美女在线视频| 午夜免费久久看| 伊人一区二区三区| 午夜日韩在线观看| 蜜桃视频第一区免费观看| 久久国产精品露脸对白| 精品一区二区影视| 成人在线一区二区三区| 91美女精品福利| 欧美三级蜜桃2在线观看| 欧美日韩视频专区在线播放| 欧美精三区欧美精三区| 日韩欧美国产一区在线观看| 久久免费电影网| 亚洲欧美日韩国产成人精品影院| 亚洲亚洲人成综合网络| 午夜精品福利一区二区蜜股av | 日韩写真欧美这视频| 国产亚洲欧洲一区高清在线观看| 中文字幕中文字幕在线一区| 欧美不卡激情三级在线观看| 国产乱子伦视频一区二区三区| 国产精品视频在线看| 天天综合色天天| 久久99热这里只有精品| 99视频一区二区| 91视频在线看| 色综合久久综合网97色综合| 精品99久久久久久| 亚洲女与黑人做爰| 亚洲老司机在线| 欧美激情一区二区在线| 综合自拍亚洲综合图不卡区| 国产精品家庭影院| 成人免费毛片嘿嘿连载视频| 精品一区二区免费看| 成人免费视频网站在线观看| 国产91露脸合集magnet| 色婷婷av一区二区三区大白胸| 欧美亚洲图片小说| 亚洲免费在线播放| 麻豆一区二区99久久久久| 国产精品77777| 国产一本一道久久香蕉| 337p亚洲精品色噜噜| 久久久久免费观看| 亚洲精品久久嫩草网站秘色| 99久久精品国产导航| 91精品一区二区三区在线观看| 久久女同性恋中文字幕| 国产麻豆精品久久一二三| 欧洲精品一区二区三区在线观看| 制服丝袜成人动漫| 男人的天堂久久精品| av日韩在线网站| 538在线一区二区精品国产| 午夜不卡av在线| 91网站最新网址| 国产suv一区二区三区88区| 91麻豆福利精品推荐| 国产亚洲一区二区三区在线观看| 亚洲电影在线播放| 在线亚洲人成电影网站色www| 亚洲男帅同性gay1069| 国产精品一二二区| 久久久久久久综合狠狠综合| 成人亚洲精品久久久久软件| 欧美成人a在线| 国产中文字幕精品| 亚洲美女电影在线| 91麻豆123| 天天综合日日夜夜精品| 久久久精品综合| 国产精品原创巨作av| 国产精品女同互慰在线看| 7777精品伊人久久久大香线蕉超级流畅| 国产精品乱人伦中文| 91亚洲国产成人精品一区二三| 亚洲最色的网站| 欧美另类久久久品| 一区二区三区日韩| 欧美一激情一区二区三区| 久久久91精品国产一区二区精品 | 亚洲成人免费观看| 日韩精品一区二区三区三区免费 | 亚洲线精品一区二区三区| 欧美日韩国产天堂| 麻豆精品视频在线观看视频| 日韩精品专区在线影院重磅| 国产成人av一区二区| 国产成人亚洲综合a∨婷婷 | 一区二区三区色| 亚洲免费在线视频| 久久精品一区二区三区四区| 精品久久久久一区二区国产| 成人高清视频免费观看| 亚洲国产经典视频| 中文字幕精品综合| 欧美一区二区三区电影| 色呦呦网站一区| 国产福利一区二区| 国产69精品久久久久777| 亚洲综合久久av| 欧美肥大bbwbbw高潮| 日韩午夜av电影| 欧美久久一二区| 日韩精品一区二区三区三区免费| 色婷婷av久久久久久久| 成人成人成人在线视频| 91麻豆自制传媒国产之光| 国产精品白丝av| 天堂av在线一区| 亚洲高清视频中文字幕| 国产精品系列在线| 亚洲国产成人va在线观看天堂| 中文字幕字幕中文在线中不卡视频| 国产日韩在线不卡| 欧美乱妇15p| 欧美一区二区三区免费| 91麻豆精品国产自产在线观看一区| 久久婷婷成人综合色| 精品国产乱码久久久久久图片 | 欧美剧情电影在线观看完整版免费励志电影| 国产在线精品视频| 91年精品国产| 欧美性大战久久| 国产欧美日韩亚州综合 | 欧美中文字幕久久| 在线观看日韩高清av| 91最新地址在线播放| 久久亚洲捆绑美女| 亚洲女同ⅹxx女同tv| 国产在线精品国自产拍免费| 懂色av一区二区三区免费观看 | 欧美日韩精品电影| 日韩精品中文字幕一区二区三区| 亚洲欧美日韩国产另类专区 | 国产精品成人午夜| 亚洲女厕所小便bbb| 91精品欧美一区二区三区综合在| 中文字幕中文字幕在线一区| 午夜激情一区二区| 欧美日韩在线免费视频| 精品盗摄一区二区三区|