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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? blowfish.cpp

?? IPmessage局域網(wǎng)信息
?? 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)

#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 ()
{
	PArray = new DWORD [18];
	SBoxes = new DWORD [4][256];
}

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(BYTE key[], int keybytes, Mode _mode)
{
	int  		i, j;
	DWORD		datal, datar;
	union aword	temp;

	mode = _mode;

	// first fill arrays from data tables
	for (i = 0; i < 18; 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];
	}

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

	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)
{
	if (mode == CBC)
		lInputLong++;
	return	(lInputLong / 8 + (lInputLong % 8 ? 1 : 0)) * 8;
}

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

	// Encode 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::Encode (BYTE * pInput, BYTE * pOutput, DWORD lSize)
{
	DWORD 	lCount, lOutSize, *dwOutput = (DWORD *)pOutput;
	_int64	CBCval = 0;

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

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

	for (lCount = 0; lCount < lOutSize; lCount += 8)
	{
		if (mode == CBC)
			*(_int64 *)dwOutput ^= CBCval;

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

		Blowfish_encipher(dwOutput, dwOutput + 1);

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

		if (mode == CBC)
			CBCval = *(_int64 *)dwOutput;
		dwOutput += 2;
	}

	return lOutSize;
}

	// Decode 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::Decode(BYTE * pInput, BYTE * pOutput, DWORD lSize)
{
	DWORD	lCount, *dwOutput = (DWORD *)pOutput;
	_int64	CBCval = 0, prevCBCval = 0;

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

	for (lCount = 0; lCount < lSize; lCount += 8)
	{
		if (mode == CBC)
		{
			prevCBCval = CBCval;
			CBCval = *(_int64 *)dwOutput;
		}

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

		Blowfish_decipher(dwOutput, dwOutput + 1);

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

		if (mode == CBC)
			*(_int64 *)dwOutput ^= prevCBCval;
		dwOutput += 2;
	}

	if (mode == CBC)
	{
		DWORD	paddingLen = pOutput[lCount - 1];
		if (paddingLen <= 8 && pOutput[lCount - paddingLen] == paddingLen)
			pOutput[lCount -= paddingLen] = 0;
	}
	return	lCount;
}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色久综合一二码| 日韩精品中文字幕在线不卡尤物| 国产性天天综合网| 97se亚洲国产综合在线| 国产精品视频第一区| kk眼镜猥琐国模调教系列一区二区| 亚洲人成在线播放网站岛国| 91精品在线免费| 精品亚洲国产成人av制服丝袜 | 精品视频一区 二区 三区| 欧美综合亚洲图片综合区| 欧美日韩高清一区二区不卡| 制服视频三区第一页精品| 国产精品色在线| 欧美日韩和欧美的一区二区| 国产精品卡一卡二| 日本视频一区二区三区| 日韩精品最新网址| 一本久久a久久精品亚洲| 亚洲国产精品久久久久婷婷884| 欧美videos大乳护士334| 不卡av在线网| 精品国产青草久久久久福利| 99精品国产99久久久久久白柏 | 欧美日韩一区高清| 狠狠色狠狠色综合系列| 国产日韩精品一区| 亚洲午夜久久久久| 精品国产免费久久| 91色porny在线视频| 日本亚洲免费观看| 亚洲色图视频免费播放| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 狠狠久久亚洲欧美| 奇米影视在线99精品| 日韩欧美国产一二三区| 一本色道久久综合亚洲91| 国产精品影音先锋| 伊人色综合久久天天人手人婷| 精品三级在线观看| 91麻豆精品国产| 色琪琪一区二区三区亚洲区| 国内国产精品久久| 久久成人精品无人区| 天天影视网天天综合色在线播放| xf在线a精品一区二区视频网站| 91国产福利在线| 在线免费亚洲电影| 处破女av一区二区| 美国欧美日韩国产在线播放| 天堂成人免费av电影一区| 亚洲理论在线观看| 久久九九久精品国产免费直播| 欧美四级电影网| 92国产精品观看| 国产福利一区在线| 成人黄色综合网站| 黑人巨大精品欧美黑白配亚洲| 日韩av中文字幕一区二区 | 在线播放91灌醉迷j高跟美女| 91成人在线观看喷潮| 国产成人免费视频网站高清观看视频 | 亚洲va韩国va欧美va| 国产精品传媒视频| 久久精品视频在线免费观看| 日韩一区二区三免费高清| 在线精品观看国产| 欧美肥妇毛茸茸| 欧美理论在线播放| 一区二区三区免费| 国产欧美日韩亚州综合| 国产精品国模大尺度视频| 亚洲三级在线免费观看| 亚洲精品国产一区二区三区四区在线| 午夜欧美2019年伦理| 奇米精品一区二区三区四区| 免费人成黄页网站在线一区二区| 老司机免费视频一区二区| 国产在线不卡视频| 91黄视频在线| 日韩一区国产二区欧美三区| 久久精品在线免费观看| 亚洲国产精品久久艾草纯爱| 蜜臀av亚洲一区中文字幕| 亚洲综合激情网| 国产在线播精品第三| 91丝袜高跟美女视频| 欧美成人欧美edvon| 国产精品天美传媒沈樵| 亚洲欧美日韩系列| 国产精品白丝av| 在线观看国产精品网站| 欧美一区二区黄| 亚洲男人天堂一区| 蜜桃视频一区二区| 色8久久人人97超碰香蕉987| 日韩久久久精品| 亚洲视频免费观看| 国产成人在线色| 欧日韩精品视频| 亚洲精品一区二区三区香蕉| 亚洲第一在线综合网站| 国产精品911| 欧美日韩一二三区| 中文字幕免费不卡| 丝袜亚洲精品中文字幕一区| 99久久精品一区| 日韩欧美激情在线| 亚洲免费在线观看| www.日本不卡| 日韩女同互慰一区二区| 中文字幕一区二区不卡| 国产精品香蕉一区二区三区| 宅男噜噜噜66一区二区66| 亚洲视频免费在线| 国产精品69毛片高清亚洲| 欧美精品第一页| 亚洲国产一区二区三区| 成人avav影音| 国产日韩欧美a| 激情综合色综合久久综合| 欧美日韩亚洲综合一区二区三区| 一区二区三区日韩欧美| 国产成都精品91一区二区三 | 久久婷婷国产综合精品青草| 亚洲国产精品一区二区www在线 | 精品一区二区在线看| 欧美一区二区三区四区视频| 亚洲综合色成人| 99热精品一区二区| 国产精品欧美久久久久一区二区| 精品无码三级在线观看视频| 91久久精品一区二区二区| 亚洲欧美国产毛片在线| 成人美女在线视频| 日韩无一区二区| 日本不卡视频在线观看| 欧美性猛交xxxx黑人交| 亚洲va韩国va欧美va精品| 91国产免费看| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 久久综合成人精品亚洲另类欧美| 日韩电影在线一区二区| 欧美xxxxx牲另类人与| 免费在线观看不卡| 欧美性三三影院| 亚洲国产精品麻豆| 欧美色精品天天在线观看视频| 亚洲国产一区视频| 在线观看亚洲成人| 日韩成人av影视| 日韩精品一区二区三区中文精品| 日本大胆欧美人术艺术动态| 久久网站最新地址| 国产一区二区成人久久免费影院| 久久婷婷一区二区三区| 丁香婷婷综合色啪| 国产精品短视频| 91.com在线观看| 久久99精品一区二区三区| 欧美一区二区三区思思人| 美腿丝袜亚洲三区| 久久影院视频免费| 99精品在线观看视频| 一个色妞综合视频在线观看| 欧美日韩综合色| 日本在线不卡视频一二三区| 2023国产精品自拍| 91免费看`日韩一区二区| 一区二区三区四区在线免费观看 | 日韩av电影免费观看高清完整版 | 亚洲伊人伊色伊影伊综合网| 欧美日韩在线综合| 紧缚捆绑精品一区二区| 亚洲激情自拍偷拍| 欧美日韩在线综合| 午夜私人影院久久久久| 26uuu精品一区二区在线观看| 大尺度一区二区| 日本视频免费一区| 久久色在线视频| 不卡的电影网站| 久久精品国产99国产精品| 国产欧美一区二区精品性色超碰| 欧美主播一区二区三区| 另类小说色综合网站| 国产视频一区二区三区在线观看| 欧美伊人久久大香线蕉综合69| 男女性色大片免费观看一区二区| 国产精品视频线看| 欧美日韩久久久一区| 国产经典欧美精品| 天天色 色综合| 日韩欧美二区三区| 欧美午夜一区二区三区免费大片| 精品亚洲porn| 亚洲综合清纯丝袜自拍| 国产精品久久久久久久久久免费看| 欧美亚洲图片小说| 99久久久精品|