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

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

?? blowfish.cpp

?? 飛鴿傳書的代碼 是在LINUX平臺上的 好DD哦
?? CPP
字號:
// blowfish.cpp   C++ class implementation of the BLOWFISH encryption algorithm
// _THE BLOWFISH ENCRYPTION ALGORITHM_
// by Bruce Schneier
// Revised code--3/20/94
// Converted to C++ class 5/96, Jim Conger
//
// modify H.Shirouzu 07/2002 (add change_order(), CBC mode)
// modify H.Shirouzu 01/2004 (add PKCS#5 mode)

#include <string.h>
#include "blowfish.h"
#include "blowfish.h2"	// holds the random digit tables

#define S(x,i) (SBoxes[i][x.w.byte##i])
#define bf_F(x) (((S(x,0) + S(x,1)) ^ S(x,2)) + S(x,3))
#define ROUND(a,b,n) (a.dword ^= bf_F(b) ^ PArray[n])

CBlowFish::CBlowFish (const BYTE *key, int keybytes)
{
	PArray = new DWORD [NPASS + 2];
	SBoxes = new DWORD [4][256];

	if (key)
		Initialize(key, keybytes);
}

CBlowFish::~CBlowFish ()
{
	delete [] SBoxes;
	delete [] PArray;
}

	// the low level (private) encryption function
void CBlowFish::Blowfish_encipher(DWORD *xl, DWORD *xr)
{
	union aword  Xl, Xr;

	Xl.dword = *xl;
	Xr.dword = *xr;

	Xl.dword ^= PArray[0];
	ROUND(Xr, Xl, 1);  ROUND(Xl, Xr, 2);
	ROUND(Xr, Xl, 3);  ROUND(Xl, Xr, 4);
	ROUND(Xr, Xl, 5);  ROUND(Xl, Xr, 6);
	ROUND(Xr, Xl, 7);  ROUND(Xl, Xr, 8);
	ROUND(Xr, Xl, 9);  ROUND(Xl, Xr, 10);
	ROUND(Xr, Xl, 11); ROUND(Xl, Xr, 12);
	ROUND(Xr, Xl, 13); ROUND(Xl, Xr, 14);
	ROUND(Xr, Xl, 15); ROUND(Xl, Xr, 16);
	Xr.dword ^= PArray[17];

	*xr = Xl.dword;
	*xl = Xr.dword;
}

	// the low level (private) decryption function
void CBlowFish::Blowfish_decipher(DWORD *xl, DWORD *xr)
{
	union aword  Xl;
	union aword  Xr;

	Xl.dword = *xl;
	Xr.dword = *xr;

	Xl.dword ^= PArray[17];
	ROUND(Xr, Xl, 16);  ROUND(Xl, Xr, 15);
	ROUND(Xr, Xl, 14);  ROUND(Xl, Xr, 13);
	ROUND(Xr, Xl, 12);  ROUND(Xl, Xr, 11);
	ROUND(Xr, Xl, 10);  ROUND(Xl, Xr, 9);
	ROUND(Xr, Xl, 8);   ROUND(Xl, Xr, 7);
	ROUND(Xr, Xl, 6);   ROUND(Xl, Xr, 5);
	ROUND(Xr, Xl, 4);   ROUND(Xl, Xr, 3);
	ROUND(Xr, Xl, 2);   ROUND(Xl, Xr, 1);
	Xr.dword ^= PArray[0];

	*xl = Xr.dword;
	*xr = Xl.dword;
}


	// constructs the enctryption sieve
void CBlowFish::Initialize(const BYTE *key, int keybytes)
{
	int  		i, j;
	DWORD		datal, datar;
	union aword	temp;

	// first fill arrays from data tables
	for (i = 0; i < NPASS + 2; i++)
		PArray[i] = bf_P[i];

	for (i = 0; i < 4; i++)
	{
		for (j = 0; j < 256; j++)
			SBoxes[i][j] = bf_S[i][j];
	}

	for (i=0, j=0; i < NPASS + 2; i++)
	{
		temp.w.byte0 = key[j++ % keybytes];
		temp.w.byte1 = key[j++ % keybytes];
		temp.w.byte2 = key[j++ % keybytes];
		temp.w.byte3 = key[j++ % keybytes];
		PArray[i] ^= temp.dword;
	}

	datal = datar = 0;

	for (i = 0; i < NPASS + 2; i += 2)
	{
		Blowfish_encipher(&datal, &datar);
		PArray[i] = datal;
		PArray[i + 1] = datar;
	}

	for (i = 0; i < 4; i++)
	{
		for (j = 0; j < 256; j += 2)
		{
			Blowfish_encipher(&datal, &datar);
			SBoxes[i][j] = datal;
			SBoxes[i][j + 1] = datar;
		}
	}
}

	// get output length, which must be even MOD 8
DWORD CBlowFish::GetOutputLength(DWORD lInputLong, int mode)
{
	if (mode & BF_PKCS5)
		lInputLong++;
	return	ALIGN_SIZE(lInputLong, BF_BLKSIZE);
}

	// change byte order
#ifdef ORDER_ABCD
#define change_order
#else
inline void change_order(DWORD *val)
{
	aword	org_val;
	org_val.dword = *val;

	((aword *)val)->w.byte0 = org_val.byte[0];
	((aword *)val)->w.byte1 = org_val.byte[1];
	((aword *)val)->w.byte2 = org_val.byte[2];
	((aword *)val)->w.byte3 = org_val.byte[3];
}
#endif

	// Encrypt pIntput into pOutput.  Input length in lSize.  Returned value
	// is length of output which will be even MOD 8 bytes.  Input buffer and
	// output buffer can be the same, but be sure buffer length is even MOD 8.
DWORD CBlowFish::Encrypt(const BYTE *pInput, BYTE *pOutput, DWORD lSize, int mode, _int64 IV)
{
	DWORD 	lCount, lOutSize, *dwOutput = (DWORD *)pOutput;

	if (pInput != pOutput)
		memcpy(pOutput, pInput, lSize);

	lOutSize = GetOutputLength(lSize, mode);
	memset(pOutput + lSize, (mode & BF_PKCS5) ? lOutSize - lSize : 0, lOutSize - lSize);

	for (lCount = 0; lCount < lOutSize; lCount += BF_BLKSIZE)
	{
		if (mode & BF_CBC)
			*(_int64 *)dwOutput ^= IV;

		change_order(dwOutput); change_order(dwOutput + 1);

		Blowfish_encipher(dwOutput, dwOutput + 1);

		change_order(dwOutput); change_order(dwOutput + 1);

		if (mode & BF_CBC)
			IV = *(_int64 *)dwOutput;
		dwOutput += 2;
	}

	return lCount;
}

	// Decrypt pIntput into pOutput.  Input length in lSize.  Input buffer and
	// output buffer can be the same, but be sure buffer length is even MOD 8.
DWORD CBlowFish::Decrypt(const BYTE *pInput, BYTE *pOutput, DWORD lSize, int mode, _int64 IV)
{
	DWORD	lCount, *dwOutput = (DWORD *)pOutput;
	_int64	prevIV = 0;

	if (pInput != pOutput)
		memcpy(pOutput, pInput, lSize);

	for (lCount = 0; lCount < lSize; lCount += BF_BLKSIZE)
	{
		if (mode & BF_CBC)
		{
			prevIV = IV;
			IV = *(_int64 *)dwOutput;
		}

		change_order(dwOutput); change_order(dwOutput + 1);

		Blowfish_decipher(dwOutput, dwOutput + 1);

		change_order(dwOutput); change_order(dwOutput + 1);

		if (mode & BF_CBC)
			*(_int64 *)dwOutput ^= prevIV;
		dwOutput += 2;
	}

	if (mode & BF_PKCS5)
	{
		DWORD	paddingLen = pOutput[lCount - 1];
		if (paddingLen <= 0 || paddingLen > BF_BLKSIZE || pOutput[lCount - paddingLen] != paddingLen)
			return	0;	// error
		pOutput[lCount -= paddingLen] = 0;
	}
	return	lCount;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费视频成人| 香蕉影视欧美成人| 日韩欧美激情四射| 欧美日本在线播放| 欧美偷拍一区二区| 在线视频欧美精品| 日本韩国欧美三级| 欧美视频三区在线播放| 欧美天堂一区二区三区| 欧美精品日韩一本| 51午夜精品国产| 91精品国产免费| 欧美成人三级电影在线| 久久精品夜色噜噜亚洲a∨| 国产亚洲va综合人人澡精品| 国产女人水真多18毛片18精品视频 | 亚洲欧洲三级电影| 亚洲精品免费一二三区| 亚洲成av人片在www色猫咪| 午夜精品一区二区三区免费视频| 视频一区在线播放| 国产美女av一区二区三区| 国产馆精品极品| 91久久国产综合久久| 91精品国产欧美一区二区成人 | 国产剧情一区二区三区| 成人深夜福利app| 色网站国产精品| 91精品国产综合久久香蕉麻豆| 久久久午夜电影| 一区二区三区四区国产精品| 秋霞午夜鲁丝一区二区老狼| 国产精品一区二区你懂的| 色呦呦一区二区三区| 欧美一区二区三区不卡| 国产精品传媒入口麻豆| 日韩极品在线观看| 成人妖精视频yjsp地址| 欧美老女人在线| 国产清纯在线一区二区www| 亚洲最色的网站| 国产福利一区二区三区视频在线| 欧美性受极品xxxx喷水| 国产网站一区二区| 日韩高清在线电影| 色综合天天综合色综合av| 精品理论电影在线观看| 一区二区三区久久| 粉嫩13p一区二区三区| 欧美在线观看一区二区| 中文字幕精品—区二区四季| 美女在线观看视频一区二区| 91豆麻精品91久久久久久| 国产视频一区不卡| 久久99国产精品久久99 | 欧美一区二区三区人| 国产精品卡一卡二| 国内成人免费视频| 欧美一区二区三区在线观看| 亚洲欧美另类综合偷拍| 国产不卡一区视频| www国产成人| 日本亚洲最大的色成网站www| 色狠狠一区二区| 中文字幕亚洲视频| 不卡的av在线| 久久精品人人爽人人爽| 久草在线在线精品观看| 日韩视频在线永久播放| 日本不卡中文字幕| 欧美电影在线免费观看| 亚洲国产乱码最新视频| 欧美亚洲一区二区三区四区| 亚洲精品菠萝久久久久久久| 色综合网色综合| 亚洲日本va在线观看| 99久久久国产精品免费蜜臀| 国产精品国产馆在线真实露脸| 成人午夜av电影| 亚洲天堂福利av| 91色视频在线| 亚洲一二三区不卡| 69堂亚洲精品首页| 蜜桃视频一区二区三区在线观看 | 狠狠色丁香九九婷婷综合五月| 日韩午夜激情电影| 精东粉嫩av免费一区二区三区| 日韩三级免费观看| 韩国午夜理伦三级不卡影院| 国产午夜一区二区三区| 粉嫩av一区二区三区| 亚洲精品国产无天堂网2021| 欧美日韩高清影院| 国产综合久久久久影院| 中文字幕免费不卡在线| 91精品1区2区| 毛片av一区二区| 国产精品护士白丝一区av| 色天天综合色天天久久| 日本不卡不码高清免费观看| 精品久久久久久亚洲综合网| 国产成人在线观看免费网站| 亚洲天堂精品视频| 日韩欧美在线影院| 成人国产电影网| 日韩精品乱码av一区二区| 久久婷婷国产综合精品青草| 91毛片在线观看| 精品亚洲免费视频| 亚洲自拍偷拍麻豆| 精品999久久久| 91麻豆国产精品久久| 免费高清不卡av| 亚洲女子a中天字幕| 日韩三级伦理片妻子的秘密按摩| 成人高清视频在线| 奇米一区二区三区| 亚洲天堂久久久久久久| 精品久久久三级丝袜| 欧美撒尿777hd撒尿| 国产二区国产一区在线观看| 午夜精品福利一区二区三区av| wwwwww.欧美系列| 欧美日韩国产bt| 一本色道亚洲精品aⅴ| 国产精品1区2区| 日本在线不卡视频一二三区| 最新成人av在线| 国产日韩在线不卡| 欧美一区二区三区视频免费播放| 9人人澡人人爽人人精品| 麻豆91免费看| 首页国产丝袜综合| 亚洲激情在线播放| 国产精品久久久久婷婷二区次| 日韩欧美中文字幕公布| 欧美美女直播网站| 欧美亚洲国产一区二区三区| 99精品国产视频| 国产成人aaa| 国产剧情av麻豆香蕉精品| 免费人成在线不卡| 日本麻豆一区二区三区视频| 亚洲一区在线看| 亚洲欧洲成人av每日更新| 久久精品一区二区三区不卡| 精品国产1区二区| 精品99999| 久久女同性恋中文字幕| 精品国精品自拍自在线| 欧美高清精品3d| 欧美日韩国产精选| 欧美精品亚洲二区| 日韩欧美在线观看一区二区三区| 欧美日韩大陆在线| 欧美日韩国产在线观看| 欧美顶级少妇做爰| 日韩午夜在线观看| 精品久久久久99| 国产网站一区二区| 亚洲欧美在线视频观看| 亚洲女人****多毛耸耸8| 怡红院av一区二区三区| 亚洲成在线观看| 久久精品国产99国产| 久久国产精品99久久人人澡| 国产剧情一区在线| av电影在线观看一区| 色综合久久中文综合久久牛| 欧美在线一二三| 日韩欧美区一区二| 国产日韩欧美a| 亚洲少妇最新在线视频| 亚洲一线二线三线视频| 美女一区二区在线观看| 国产很黄免费观看久久| 色先锋久久av资源部| 欧美一区二区大片| 国产色一区二区| 一区二区日韩电影| 麻豆91免费观看| 99国产精品久久| 91精品国产综合久久福利软件| 久久亚洲精品小早川怜子| 亚洲视频网在线直播| 亚洲成av人片一区二区梦乃| 极品少妇一区二区三区精品视频| 成人sese在线| 欧美一区二视频| 国产精品久久久久桃色tv| 午夜久久久久久久久久一区二区| 国产高清不卡二三区| 欧美日韩在线播放三区| 国产日韩av一区二区| 亚洲3atv精品一区二区三区| 成人在线视频一区二区| 欧美老肥妇做.爰bbww视频| 国产精品免费丝袜| 奇米色一区二区| 91久久国产综合久久|