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

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

?? blowfish.cpp

?? 飛鴿傳書 可以在局域網上應用一些關于文件傳輸的 高速且有效
?? 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;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本成人在线一区| 国产精品丝袜久久久久久app| 久久国产欧美日韩精品| 亚洲精品国久久99热| 国产精品久久一卡二卡| 国产日产精品一区| 久久色.com| 日韩欧美自拍偷拍| 欧美裸体bbwbbwbbw| 欧美最新大片在线看| 97se狠狠狠综合亚洲狠狠| 国产麻豆91精品| 丰满岳乱妇一区二区三区| 国产一本一道久久香蕉| 在线电影一区二区三区| 亚洲美女在线一区| 亚洲国产综合91精品麻豆| 国产欧美日韩久久| 91香蕉视频在线| 日本不卡免费在线视频| 麻豆国产91在线播放| 蜜桃在线一区二区三区| 精品视频1区2区| 精品少妇一区二区三区免费观看| 久久久久久久久97黄色工厂| 亚洲婷婷综合色高清在线| 午夜久久电影网| 日韩成人dvd| 正在播放一区二区| 久久蜜桃av一区精品变态类天堂| 日本午夜一本久久久综合| 欧美日韩三级视频| 亚洲福利一二三区| 欧美精品一级二级| 蜜桃视频在线观看一区二区| 欧美一区二区在线看| 中文字幕在线观看不卡| 中文av字幕一区| 欧美日韩免费观看一区二区三区| 久久久久久久久久久久久久久99| 亚洲一区视频在线观看视频| 美美哒免费高清在线观看视频一区二区 | 欧美久久高跟鞋激| 亚洲成人一区二区在线观看| 国产美女精品人人做人人爽| 久久亚洲一区二区三区明星换脸| 国产综合色视频| 欧美日韩在线播放一区| 亚洲成在人线在线播放| 欧美一区二区成人| 国产伦精品一区二区三区免费迷| 久久精品综合网| 日韩av高清在线观看| 欧美mv和日韩mv的网站| 成人激情黄色小说| 亚洲欧美日韩一区二区三区在线观看| 一区二区三区四区不卡在线| 亚洲va欧美va天堂v国产综合| 欧美高清激情brazzers| 麻豆免费精品视频| 综合在线观看色| 在线不卡免费欧美| 国产精品18久久久久久久久| 91在线丨porny丨国产| 一区二区三区久久| 精品国产a毛片| 美女一区二区三区| 国产精品福利一区| 91国偷自产一区二区三区观看 | 3atv在线一区二区三区| 国产尤物一区二区| 亚洲欧美另类小说视频| 欧美va在线播放| 色呦呦国产精品| 中文字幕日韩一区| 欧美一区二区三区免费在线看 | 97se亚洲国产综合自在线| 一区二区三区日韩精品视频| 欧美一级理论片| av不卡一区二区三区| 久久嫩草精品久久久久| 欧美专区日韩专区| 国产精品123| 日本aⅴ免费视频一区二区三区| 国产精品久久久久久妇女6080| 这里只有精品免费| 91在线云播放| 成人午夜av在线| 中文字幕一区日韩精品欧美| 欧美一级精品在线| 欧美性xxxxxx少妇| 日韩vs国产vs欧美| 亚洲最新在线观看| 国产精品高清亚洲| 国产色一区二区| 精品播放一区二区| 欧美一区二区黄色| 色又黄又爽网站www久久| 91在线看国产| 中文字幕亚洲精品在线观看| 日韩精品一区二区三区三区免费| 欧美aaa在线| 亚洲高清中文字幕| 亚洲第一精品在线| 一区二区三区国产豹纹内裤在线| 中文字幕免费不卡| 欧美日韩在线精品一区二区三区激情| 国产 欧美在线| 粉嫩蜜臀av国产精品网站| 久久99精品久久久久久久久久久久 | 国产精品传媒入口麻豆| 国产亚洲精品bt天堂精选| 欧美成人在线直播| 精品国产乱码久久久久久蜜臀| 欧美一二三四在线| 日韩欧美高清一区| 精品av久久707| 久久久久久久一区| 欧美国产一区二区在线观看| 国产欧美一区二区精品忘忧草| 久久久久久久久97黄色工厂| 国产日本亚洲高清| 成人欧美一区二区三区| 综合色中文字幕| 亚洲中国最大av网站| 亚洲va韩国va欧美va精品| 五月天欧美精品| 久久精品国产澳门| 国产精品91一区二区| 成人精品国产福利| 色综合久久88色综合天天免费| 色国产精品一区在线观看| 欧美视频精品在线观看| 91麻豆精品国产自产在线| 精品国产乱码久久久久久老虎| 久久婷婷综合激情| 国产精品美女久久久久久| 一区二区高清免费观看影视大全| 亚洲18女电影在线观看| 久久电影网电视剧免费观看| 大白屁股一区二区视频| 欧亚洲嫩模精品一区三区| 日韩欧美的一区二区| 国产日本欧洲亚洲| 亚洲一区二区精品视频| 毛片一区二区三区| 99久久婷婷国产综合精品| 亚洲一区在线看| 亚洲高清不卡在线| 国产成人午夜视频| 成人免费高清在线| 国产偷v国产偷v亚洲高清| 久久久久久亚洲综合影院红桃| 中文字幕第一区综合| 亚洲一区二区视频| 国产精品伊人色| 欧美视频一区二区三区在线观看 | 久久嫩草精品久久久精品一| 亚洲色图一区二区三区| 日韩av一区二| 一本久久精品一区二区| 亚洲精品一区二区三区精华液| 亚洲免费观看高清| 国产精品1区2区3区在线观看| 欧美色图12p| 国产精品灌醉下药二区| 麻豆国产欧美一区二区三区| 色综合天天综合网国产成人综合天| 性欧美疯狂xxxxbbbb| 国产成人精品亚洲日本在线桃色 | 午夜日韩在线电影| 97精品国产露脸对白| 日韩一区二区免费在线电影| 亚洲色图色小说| 久久99精品久久久久婷婷| 欧美日韩激情在线| 中文字幕日韩欧美一区二区三区| 久久99蜜桃精品| 欧美视频中文字幕| 一区二区国产盗摄色噜噜| 丁香另类激情小说| 日韩精品中文字幕一区| 视频一区中文字幕国产| 午夜亚洲福利老司机| 99精品欧美一区二区三区小说| 久久久久久久综合色一本| 蜜臀av一区二区| 91精品国产91综合久久蜜臀| 亚洲最新视频在线观看| 日本韩国精品一区二区在线观看| 国产精品久久久一本精品| 懂色av噜噜一区二区三区av| 久久亚洲私人国产精品va媚药| 久久精品国产精品亚洲精品| 欧美精品aⅴ在线视频| 天堂一区二区在线| 91精品国产色综合久久不卡蜜臀| 亚洲亚洲人成综合网络| 欧美性xxxxx极品少妇| 亚洲图片欧美色图|