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

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

?? evaqqcrypt.cpp

?? 我自己制作的用于分析qq協議的工作
?? CPP
字號:
#include "stdafx.h"
#include "evaqqcrypt.h"
#include <Winsock2.h>

EvaQQCrypt::EvaQQCrypt(void)
{
}

EvaQQCrypt::~EvaQQCrypt(void)
{
}

void EvaQQCrypt::Tea_Encipher(unsigned long *const v, const unsigned long *const k, unsigned long *const w)
{
	register unsigned long 		y     = ntohl(v[0]),		z     = ntohl(v[1]),		a     = ntohl(k[0]),		b     = ntohl(k[1]),		c     = ntohl(k[2]),		d     = ntohl(k[3]),		n     = 0x10,       /* do encrypt 16 (0x10) times */		sum   = 0,		delta = 0x9E3779B9; /*  0x9E3779B9 - 0x100000000 = -0x61C88647 */	while (n-- > 0) {		sum += delta;		y += ((z << 4) + a) ^ (z + sum) ^ ((z >> 5) + b);		z += ((y << 4) + c) ^ (y + sum) ^ ((y >> 5) + d);	}	w[0] = htonl(y); w[1] = htonl(z);
}
void EvaQQCrypt::Tea_Decipher(unsigned long *const v, const unsigned long *const k, unsigned long *const w)
{
	register unsigned long		y     = ntohl(v[0]),		z     = ntohl(v[1]),		a     = ntohl(k[0]),		b     = ntohl(k[1]),		c     = ntohl(k[2]),		d     = ntohl(k[3]),		n     = 0x10,		sum   = 0xE3779B90, 		/* why this ? must be related with n value*/		delta = 0x9E3779B9;	/* sum = delta<<5, in general sum = delta * n */	while (n-- > 0) {		z -= ((y << 4) + c) ^ (y + sum) ^ ((y >> 5) + d);		y -= ((z << 4) + a) ^ (z + sum) ^ ((z >> 5) + b);		sum -= delta;	}	w[0] = htonl(y); w[1] = htonl(z);
}

void EvaQQCrypt::Encrypt (  						  unsigned char*  instr,						  int             instrlen,						  unsigned char*  key,						  unsigned char*  outstr,						  int*            outstrlen_prt)
{
	unsigned char 		plain[8],         /* plain text buffer*/		plain_pre_8[8],   /* plain text buffer, previous 8 bytes*/		* crypted,        /* crypted text*/		* crypted_pre_8,  /* crypted test, previous 8 bytes*/		* inp;            /* current position in instr*/	int 		pos_in_byte = 1,  /* loop in the byte */		is_header=1,      /* header is one byte*/		count=0,          /* number of bytes being crypted*/		padding = 0;      /* number of padding stuff*/	//void encrypt_every_8_byte (void);    	/*** we encrypt every eight byte ***/#define encrypt_every_8_byte()  \	{\	for(pos_in_byte=0; pos_in_byte<8; pos_in_byte++) {\	if(is_header) { plain[pos_in_byte] ^= plain_pre_8[pos_in_byte]; }\			else { plain[pos_in_byte] ^= crypted_pre_8[pos_in_byte]; }\	} /* prepare plain text*/\	Tea_Encipher( (unsigned long *) plain,\	(unsigned long *) key, \	(unsigned long *) crypted);   /* encrypt it*/\	\	for(pos_in_byte=0; pos_in_byte<8; pos_in_byte++) {\	crypted[pos_in_byte] ^= plain_pre_8[pos_in_byte]; \	} \	memcpy(plain_pre_8, plain, 8);     /* prepare next*/\	\	crypted_pre_8   =   crypted;       /* store position of previous 8 byte*/\	crypted         +=  8;             /* prepare next output*/\	count           +=  8;             /* outstrlen increase by 8*/\	pos_in_byte     =   0;             /* back to start*/\	is_header       =   0;             /* and exit header*/\	}/* encrypt_every_8_byte*/	pos_in_byte = (instrlen + 0x0a) % 8; /* header padding decided by instrlen*/	if (pos_in_byte) { 		pos_in_byte = 8 - pos_in_byte; 	}	plain[0] = (rand() & 0xf8) | pos_in_byte;	memset(plain+1, rand()&0xff, pos_in_byte++);	memset(plain_pre_8, 0x00, sizeof(plain_pre_8));	crypted = crypted_pre_8 = outstr;	padding = 1; /* pad some stuff in header*/	while (padding <= 2) { /* at most two byte */		if(pos_in_byte < 8) { plain[pos_in_byte++] = rand() & 0xff; padding ++; } 		if(pos_in_byte == 8){ encrypt_every_8_byte(); } 	}	inp = instr;	while (instrlen > 0) {		if (pos_in_byte < 8) { plain[pos_in_byte++] = *(inp++); instrlen --; }		if (pos_in_byte == 8){ encrypt_every_8_byte(); }	}	padding = 1; /* pad some stuff in tailer*/	while (padding <= 7) { /* at most sever byte*/		if (pos_in_byte < 8) { plain[pos_in_byte++] = 0x00; padding ++; }		if (pos_in_byte == 8){ encrypt_every_8_byte(); }	} 	*outstrlen_prt = count;

}

int EvaQQCrypt::rand(void)
{
	/* it can be the real random seed function*/	return 0xdead; /* override with number, convenient for debug*/	
}

int EvaQQCrypt::Decrypt (						 unsigned char*  instr,						 int             instrlen,						 unsigned char*  key,						 unsigned char*  outstr,						 int*            outstrlen_ptr){	unsigned char 		decrypted[8], m[8],		* crypt_buff, 		* crypt_buff_pre_8, 		* outp;	int 		count, 		context_start, 		pos_in_byte, 		padding;#define decrypt_every_8_byte()  {\	bool bNeedRet = false;\	for (pos_in_byte = 0; pos_in_byte < 8; pos_in_byte ++ ) {\	if (context_start + pos_in_byte >= instrlen) \	{\	bNeedRet = true;\	break;\	}\	decrypted[pos_in_byte] ^= crypt_buff[pos_in_byte];\	}\	if( !bNeedRet ) { \	Tea_Decipher( (unsigned long *) decrypted, \	(unsigned long *) key, \	(unsigned long *) decrypted);\	\	context_start +=  8;\	crypt_buff    +=  8;\	pos_in_byte   =   0;\	}\}/* decrypt_every_8_byte*/	/* at least 16 bytes and %8 == 0*/	if ((instrlen % 8) || (instrlen < 16)) return 0; 	/* get information from header*/	Tea_Decipher( (unsigned long *) instr, 		(unsigned long *) key, 		(unsigned long *) decrypted);	pos_in_byte = decrypted[0] & 0x7;	count = instrlen - pos_in_byte - 10; /* this is the plaintext length*/	/* return if outstr buffer is not large enought or error plaintext length*/	if (*outstrlen_ptr < count || count < 0) return 0;	memset(m, 0, 8);	crypt_buff_pre_8 = m;	*outstrlen_ptr = count;   /* everything is ok! set return string length*/	crypt_buff = instr + 8;   /* address of real data start */	context_start = 8;        /* context is at the second 8 byte*/	pos_in_byte ++;           /* start of paddng stuffv*/	padding = 1;              /* at least one in header*/	while (padding <= 2) {    /* there are 2 byte padding stuff in header*/		if (pos_in_byte < 8) {  /* bypass the padding stuff, none sense data*/			pos_in_byte ++; padding ++;		}		if (pos_in_byte == 8) {			crypt_buff_pre_8 = instr;			//if (! decrypt_every_8_byte()) return 0; 			decrypt_every_8_byte();		}	}/* while*/	outp = outstr;	while(count !=0) {		if (pos_in_byte < 8) {			*outp = crypt_buff_pre_8[pos_in_byte] ^ decrypted[pos_in_byte];			outp ++;			count --;			pos_in_byte ++;		}		if (pos_in_byte == 8) {			crypt_buff_pre_8 = crypt_buff - 8;			//if (! decrypt_every_8_byte()) return 0;			decrypt_every_8_byte();		}	}/* while*/	for (padding = 1; padding < 8; padding ++) {		if (pos_in_byte < 8) {			if (crypt_buff_pre_8[pos_in_byte] ^ decrypted[pos_in_byte]) return 0;			pos_in_byte ++; 		}		if (pos_in_byte == 8 ) {			crypt_buff_pre_8 = crypt_buff;			//if (! decrypt_every_8_byte()) return 0; 			decrypt_every_8_byte();		}	}/* for*/	return 1;}
int EvaQQCrypt::qq_crypt (						  unsigned char   flag,						  unsigned char*  instr,						  int             instrlen,						  unsigned char*  key,						  unsigned char*  outstr,						  int*            outstrlen_ptr){	if (flag == DECRYPT)		return EvaQQCrypt::Decrypt(instr, instrlen, key, outstr, outstrlen_ptr);	else 		if (flag == ENCRYPT)			EvaQQCrypt::Encrypt(instr, instrlen, key, outstr, outstrlen_ptr);	return 1; /* flag must be DECRYPT or ENCRYPT*/}/* qq_crypt*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆精品在线观看| 欧美在线一二三四区| 免费一级片91| 日韩国产在线一| 美女网站一区二区| 狂野欧美性猛交blacked| 麻豆极品一区二区三区| 国产在线精品一区二区夜色| 久国产精品韩国三级视频| 国内成人自拍视频| 成人午夜又粗又硬又大| 91在线一区二区| 欧美美女直播网站| 欧美精品一区二| 中文成人综合网| 亚洲毛片av在线| 日韩精品亚洲专区| 国产精品伊人色| 日本乱人伦aⅴ精品| 91精品国产色综合久久| 久久综合久久99| **网站欧美大片在线观看| 亚洲不卡在线观看| 国内外精品视频| 91一区二区三区在线播放| 欧美高清www午色夜在线视频| 精品日韩在线观看| 亚洲人成小说网站色在线| 美女视频一区二区| 91在线无精精品入口| 91精品在线免费观看| 亚洲国产高清不卡| 天堂久久一区二区三区| 成人黄色一级视频| 91精品国产麻豆国产自产在线| 国产欧美一区二区精品仙草咪| 亚洲影视在线观看| 成人一级黄色片| 欧美狂野另类xxxxoooo| 国产日本欧洲亚洲| 美女性感视频久久| 欧美色涩在线第一页| 国产精品色在线| 久久精品国产免费看久久精品| 91污在线观看| 久久精品视频网| 日韩国产精品久久久久久亚洲| bt欧美亚洲午夜电影天堂| 久久综合九色综合久久久精品综合| 一区二区三区小说| 不卡大黄网站免费看| 久久久久久97三级| 久久精品99国产精品| 欧美精品一二三| 亚洲国产欧美另类丝袜| 91在线视频网址| 国产精品久久久久一区| 国产精品一区二区久久不卡| 欧美一级专区免费大片| 偷拍一区二区三区| 欧美亚洲一区二区在线观看| 国产精品久久久久久久久搜平片| 国产综合久久久久久鬼色| 91麻豆精品91久久久久久清纯| 亚洲一本大道在线| 欧美日韩在线播放| 亚洲综合偷拍欧美一区色| 91视频在线看| 亚洲女人小视频在线观看| 99re热这里只有精品免费视频| 中文字幕不卡在线观看| 成人免费高清在线| 亚洲三级在线观看| 色婷婷av一区二区三区软件| 中文字幕在线不卡一区| 91蜜桃网址入口| 亚洲精品国产无套在线观| 91欧美一区二区| 亚洲一区二区中文在线| 69成人精品免费视频| 日韩电影一区二区三区| 日韩欧美一级在线播放| 久久国产精品99久久人人澡| 精品国产1区二区| 盗摄精品av一区二区三区| 亚洲欧洲av一区二区三区久久| 91亚洲精品一区二区乱码| 亚洲精品亚洲人成人网在线播放| 欧美视频精品在线| 日本视频一区二区| 2014亚洲片线观看视频免费| 风间由美性色一区二区三区| 亚洲欧美成人一区二区三区| 欧美私模裸体表演在线观看| 美女国产一区二区三区| 久久久欧美精品sm网站| 91亚洲大成网污www| 亚洲综合无码一区二区| 欧美成人aa大片| av电影一区二区| 青椒成人免费视频| 欧美激情在线一区二区三区| 欧美图区在线视频| 国产成人鲁色资源国产91色综 | 成人免费视频国产在线观看| 亚洲精品成人少妇| 26uuu另类欧美亚洲曰本| 91免费观看视频| 免费在线看成人av| 国产精品久久久久久久久搜平片| 欧美日韩国产欧美日美国产精品| 国产精品69毛片高清亚洲| 一区二区欧美在线观看| 久久久精品人体av艺术| 欧美日韩在线直播| 成人精品视频一区二区三区| 日日摸夜夜添夜夜添国产精品| 欧美激情在线一区二区| 日韩亚洲电影在线| 欧美午夜理伦三级在线观看| 日韩一级免费一区| 亚洲视频一区二区免费在线观看| 欧美视频你懂的| 懂色中文一区二区在线播放| 亚洲6080在线| 亚洲三级在线看| 久久久精品人体av艺术| 69av一区二区三区| 色拍拍在线精品视频8848| 国产91丝袜在线观看| 日本美女一区二区| 亚洲欧美另类久久久精品2019| 久久男人中文字幕资源站| 欧美一区二区三区播放老司机| 欧美亚洲自拍偷拍| 96av麻豆蜜桃一区二区| 成人美女在线观看| 国产精品一品视频| 国产一区二区精品久久99| 老司机免费视频一区二区| 日韩一区在线免费观看| 26uuu国产电影一区二区| 欧美日韩一区二区三区四区五区| 99视频精品免费视频| 国产成人精品www牛牛影视| 精品一区二区三区在线视频| 免费在线观看不卡| 美女一区二区视频| 韩国成人福利片在线播放| 久久精品国产亚洲a| 久草中文综合在线| 激情五月激情综合网| 韩国女主播一区| 国产自产视频一区二区三区| 国精产品一区一区三区mba视频| 久久成人精品无人区| 国产一区二区三区蝌蚪| 风流少妇一区二区| 93久久精品日日躁夜夜躁欧美| 99国产精品久久久久| 在线影院国内精品| 91精品欧美久久久久久动漫| 日韩欧美一级在线播放| 精品久久久网站| 国产欧美精品一区二区色综合 | 国产中文字幕一区| 国产剧情一区在线| 成人免费看视频| 在线免费观看视频一区| 7799精品视频| 2024国产精品| 国产精品久久久久一区| 91蜜桃在线观看| 67194成人在线观看| 精品一区二区三区视频在线观看| 色综合 综合色| 日韩一区二区三区免费看| 宅男在线国产精品| 日韩天堂在线观看| 国产精品国产三级国产aⅴ中文 | 日韩精品午夜视频| 国产一区视频导航| 色吧成人激情小说| 精品国产髙清在线看国产毛片| 国产精品色哟哟| 青青草成人在线观看| 91香蕉视频污| 精品国产一区二区三区不卡| 亚洲精品欧美在线| 国产一区二区在线观看视频| 色综合久久综合网| 欧美精品一区二区三区在线播放 | 久久嫩草精品久久久精品| 1024成人网色www| 欧美aaaaa成人免费观看视频| 成人精品小蝌蚪| 精品久久久久久综合日本欧美| 亚洲激情在线播放| 国产成人啪免费观看软件| 在线观看91av|