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

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

?? shark.cpp

?? 使用C實現的300中常用加密算法
?? CPP
字號:
// shark.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "shark.h"

#ifdef WORD64_AVAILABLE

#include "modes.h"
#include "gf256.h"

NAMESPACE_BEGIN(CryptoPP)

static word64 SHARKTransform(word64 a)
{
	static const byte iG[8][8] = {
		0xe7, 0x30, 0x90, 0x85, 0xd0, 0x4b, 0x91, 0x41, 
		0x53, 0x95, 0x9b, 0xa5, 0x96, 0xbc, 0xa1, 0x68, 
		0x02, 0x45, 0xf7, 0x65, 0x5c, 0x1f, 0xb6, 0x52, 
		0xa2, 0xca, 0x22, 0x94, 0x44, 0x63, 0x2a, 0xa2, 
		0xfc, 0x67, 0x8e, 0x10, 0x29, 0x75, 0x85, 0x71, 
		0x24, 0x45, 0xa2, 0xcf, 0x2f, 0x22, 0xc1, 0x0e, 
		0xa1, 0xf1, 0x71, 0x40, 0x91, 0x27, 0x18, 0xa5, 
		0x56, 0xf4, 0xaf, 0x32, 0xd2, 0xa4, 0xdc, 0x71, 
	};

	word64 result=0;
	GF256 gf256(0xf5);
	for (unsigned int i=0; i<8; i++)
		for(unsigned int j=0; j<8; j++) 
			result ^= word64(gf256.Multiply(iG[i][j], a>>(56-8*j))) << (56-8*i);
	return result;
}

void SHARKBase::InitEncryptionRoundKeys(const byte *key, unsigned int keyLen, unsigned int rounds, word64 *roundkeys)
{
	// concatenate key enought times to fill a
	for (unsigned int i=0; i<(rounds+1)*8; i++)
		((byte *)roundkeys)[i] = key[i%keyLen];

	SHARKEncryption e;
	byte IV[8] = {0,0,0,0,0,0,0,0};
	CFBEncryption cfb(e, IV);

	cfb.ProcessString((byte *)roundkeys, (rounds+1)*8);

#ifdef IS_LITTLE_ENDIAN
	byteReverse(roundkeys, roundkeys, (rounds+1)*8);
#endif

	roundkeys[rounds] = SHARKTransform(roundkeys[rounds]);
}

// construct an SHARKEncryption object with fixed round keys, to be used to initialize actual round keys
SHARKEncryption::SHARKEncryption()
	: SHARKBase(ROUNDS)
{
	for (unsigned int i=0; i<ROUNDS; i++)
		roundkeys[i] = cbox[0][i];

	roundkeys[ROUNDS] = SHARKTransform(cbox[0][ROUNDS]);

#ifdef IS_LITTLE_ENDIAN
	roundkeys[0] = byteReverse(roundkeys[0]);
	roundkeys[ROUNDS] = byteReverse(roundkeys[ROUNDS]);
#endif
}

SHARKEncryption::SHARKEncryption(const byte *key, unsigned int keyLen, unsigned int rounds)
	: SHARKBase(rounds)
{
	InitEncryptionRoundKeys(key, keyLen, rounds, roundkeys);

#ifdef IS_LITTLE_ENDIAN
	roundkeys[0] = byteReverse(roundkeys[0]);
	roundkeys[rounds] = byteReverse(roundkeys[rounds]);
#endif
}

void SHARKEncryption::ProcessBlock(const byte *in, byte *out) const
{
	word64 tmp = *(word64 *)in ^ roundkeys[0];

#ifdef IS_LITTLE_ENDIAN
	tmp = cbox[0][GETBYTE(tmp, 0)] ^ cbox[1][GETBYTE(tmp, 1)] 
		^ cbox[2][GETBYTE(tmp, 2)] ^ cbox[3][GETBYTE(tmp, 3)] 
		^ cbox[4][GETBYTE(tmp, 4)] ^ cbox[5][GETBYTE(tmp, 5)] 
		^ cbox[6][GETBYTE(tmp, 6)] ^ cbox[7][GETBYTE(tmp, 7)]
		^ roundkeys[1];
#else
	tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
		^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
		^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
		^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
		^ roundkeys[1];
#endif

	for(unsigned int i=2; i<rounds; i++) 
	{
		tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
			^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
			^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
			^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
			^ roundkeys[i];
	}

	out[0] = sbox[GETBYTE(tmp, 7)];
	out[1] = sbox[GETBYTE(tmp, 6)];
	out[2] = sbox[GETBYTE(tmp, 5)];
	out[3] = sbox[GETBYTE(tmp, 4)];
	out[4] = sbox[GETBYTE(tmp, 3)];
	out[5] = sbox[GETBYTE(tmp, 2)];
	out[6] = sbox[GETBYTE(tmp, 1)];
	out[7] = sbox[GETBYTE(tmp, 0)];

	*(word64 *)out ^= roundkeys[rounds];
}

SHARKDecryption::SHARKDecryption(const byte *key, unsigned int keyLen, unsigned int rounds)
	: SHARKBase(rounds)
{
	InitEncryptionRoundKeys(key, keyLen, rounds, roundkeys);

	unsigned int i;

	// transform encryption round keys into decryption round keys
	for (i=0; i<rounds/2; i++)
		std::swap(roundkeys[i], roundkeys[rounds-i]);

	for (i=1; i<rounds; i++)
		roundkeys[i] = SHARKTransform(roundkeys[i]);

#ifdef IS_LITTLE_ENDIAN
	roundkeys[0] = byteReverse(roundkeys[0]);
	roundkeys[rounds] = byteReverse(roundkeys[rounds]);
#endif
}

void SHARKDecryption::ProcessBlock(const byte *in, byte *out) const
{
	word64 tmp = *(word64 *)in ^ roundkeys[0];

#ifdef IS_LITTLE_ENDIAN
	tmp = cbox[0][GETBYTE(tmp, 0)] ^ cbox[1][GETBYTE(tmp, 1)] 
		^ cbox[2][GETBYTE(tmp, 2)] ^ cbox[3][GETBYTE(tmp, 3)] 
		^ cbox[4][GETBYTE(tmp, 4)] ^ cbox[5][GETBYTE(tmp, 5)] 
		^ cbox[6][GETBYTE(tmp, 6)] ^ cbox[7][GETBYTE(tmp, 7)]
		^ roundkeys[1];
#else
	tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
		^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
		^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
		^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
		^ roundkeys[1];
#endif

	for(unsigned int i=2; i<rounds; i++) 
	{
		tmp = cbox[0][GETBYTE(tmp, 7)] ^ cbox[1][GETBYTE(tmp, 6)] 
			^ cbox[2][GETBYTE(tmp, 5)] ^ cbox[3][GETBYTE(tmp, 4)] 
			^ cbox[4][GETBYTE(tmp, 3)] ^ cbox[5][GETBYTE(tmp, 2)] 
			^ cbox[6][GETBYTE(tmp, 1)] ^ cbox[7][GETBYTE(tmp, 0)]
			^ roundkeys[i];
	}

	out[0] = sbox[GETBYTE(tmp, 7)];
	out[1] = sbox[GETBYTE(tmp, 6)];
	out[2] = sbox[GETBYTE(tmp, 5)];
	out[3] = sbox[GETBYTE(tmp, 4)];
	out[4] = sbox[GETBYTE(tmp, 3)];
	out[5] = sbox[GETBYTE(tmp, 2)];
	out[6] = sbox[GETBYTE(tmp, 1)];
	out[7] = sbox[GETBYTE(tmp, 0)];

	*(word64 *)out ^= roundkeys[rounds];
}

NAMESPACE_END

#endif // WORD64_AVAILABLE

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜精品理论片a级按摩| 欧美综合视频在线观看| 日本欧美一区二区在线观看| 亚洲一区精品在线| 亚洲国产欧美在线人成| 亚洲女女做受ⅹxx高潮| 亚洲精品免费视频| 一区二区三区欧美| 亚洲一区二区美女| 亚洲h动漫在线| 青青草伊人久久| 久久不见久久见免费视频1| 美女在线观看视频一区二区| 韩国女主播成人在线观看| 韩国女主播成人在线| 国产激情精品久久久第一区二区| 国模冰冰炮一区二区| 国产白丝网站精品污在线入口| 高清视频一区二区| 91看片淫黄大片一级| 欧美三级在线视频| 日韩一区二区三区高清免费看看| 日韩女优电影在线观看| 国产丝袜欧美中文另类| 亚洲欧美视频一区| 舔着乳尖日韩一区| 韩国成人福利片在线播放| 成人白浆超碰人人人人| 欧美亚洲日本一区| 日韩视频永久免费| 国产日韩欧美一区二区三区乱码| 国产精品另类一区| 亚洲主播在线播放| 久久99久久99| 色诱视频网站一区| 91精品国产一区二区三区| 久久综合色之久久综合| 亚洲色图在线播放| 乱中年女人伦av一区二区| 不卡高清视频专区| 欧美精品三级日韩久久| 国产日韩av一区二区| 亚洲一区中文日韩| 久草中文综合在线| 99麻豆久久久国产精品免费 | 91精品国产综合久久久蜜臀粉嫩 | 亚洲综合久久av| 蜜桃av一区二区三区| 成人看片黄a免费看在线| 日本韩国欧美一区二区三区| 欧美一区二区精美| 国产精品二三区| 男女男精品视频| k8久久久一区二区三区| 91精品国产欧美日韩| 中文字幕在线观看不卡| 日韩高清一区二区| 成人av电影在线| 日韩欧美www| 一区二区三区资源| 国产成人自拍网| 欧美久久一区二区| 中文字幕中文在线不卡住| 日本va欧美va欧美va精品| 成人午夜视频免费看| 日韩欧美资源站| 亚洲欧美乱综合| 久久99精品久久久久久国产越南| 色综合久久中文综合久久牛| 欧美成人bangbros| 亚洲韩国精品一区| 成人美女视频在线观看18| 精品少妇一区二区三区视频免付费| 欧美日本在线看| 玉米视频成人免费看| 色先锋资源久久综合| 日本欧美一区二区三区| 91成人在线免费观看| 国产精品色在线| 97久久久精品综合88久久| 2020国产精品久久精品美国| 久久电影网电视剧免费观看| 日韩一区国产二区欧美三区| 久久精品国产**网站演员| 久久这里只有精品首页| 午夜精品成人在线视频| 本田岬高潮一区二区三区| 精品久久久久久久久久久久久久久久久 | 国产精品免费av| 国产综合色在线| 日韩精品一区二区三区在线播放 | 91豆麻精品91久久久久久| 中文字幕第一区第二区| 国产一区二三区好的| 精品嫩草影院久久| 麻豆91精品视频| 日韩欧美国产三级| 精品一区二区免费视频| 日韩免费观看2025年上映的电影 | 欧美色图12p| 亚洲精选视频在线| 91啦中文在线观看| 一二三区精品视频| 欧美日韩视频第一区| 午夜精品久久久| 在线播放中文字幕一区| 亚洲va欧美va人人爽| 欧美一区日本一区韩国一区| 日本vs亚洲vs韩国一区三区二区 | 亚洲天堂av老司机| 91小宝寻花一区二区三区| 亚洲视频在线观看一区| 91在线观看一区二区| 亚洲一区二区三区四区五区黄| 欧美日韩一卡二卡三卡| 青青草原综合久久大伊人精品 | 欧美日韩一区二区在线观看| 日韩精品一二三| 欧美一区二区三区在线观看视频| 秋霞成人午夜伦在线观看| 精品国产污污免费网站入口 | 久久er精品视频| 久久亚洲二区三区| 成人自拍视频在线观看| 亚洲乱码国产乱码精品精98午夜 | 欧美xxxx在线观看| 国产一区999| 亚洲色图在线视频| 欧美日韩久久一区| 激情综合色综合久久综合| 国产精品全国免费观看高清 | 成a人片国产精品| 一区二区三区久久久| 欧美一区二区精品| 丁香婷婷综合五月| 亚洲综合视频在线观看| 欧美成人精品二区三区99精品| 成人精品视频一区| 亚洲成人综合视频| 久久理论电影网| 欧美中文一区二区三区| 久久99久久久久| 亚洲欧美一区二区在线观看| 6080亚洲精品一区二区| 国产99久久久国产精品潘金网站| 亚洲三级免费观看| 日韩精品一区国产麻豆| 99国产精品久久久久久久久久久| 五月天激情综合| 欧美国产欧美亚州国产日韩mv天天看完整 | 成人v精品蜜桃久久一区| 天天爽夜夜爽夜夜爽精品视频| 国产视频一区在线播放| 欧美日韩精品免费| 成人免费看视频| 美女高潮久久久| 亚洲精品欧美激情| 久久久亚洲午夜电影| 欧美亚洲日本一区| 国产成a人无v码亚洲福利| 天堂一区二区在线| 国产精品久久久久三级| 日韩欧美国产综合在线一区二区三区 | 色播五月激情综合网| 韩国女主播一区二区三区| 亚洲国产美女搞黄色| 国产欧美日韩另类一区| 日韩一区和二区| 欧美在线免费视屏| 不卡在线视频中文字幕| 麻豆成人91精品二区三区| 亚洲黄色免费网站| 中文成人综合网| 精品奇米国产一区二区三区| 色吧成人激情小说| 成人高清免费在线播放| 极品美女销魂一区二区三区| 香蕉影视欧美成人| 亚洲精品中文在线影院| 国产精品乱子久久久久| www激情久久| 5858s免费视频成人| 91福利精品第一导航| eeuss影院一区二区三区 | 欧美男女性生活在线直播观看| 99久久久精品免费观看国产蜜| 国产一区日韩二区欧美三区| 蜜臀a∨国产成人精品| 亚洲国产精品久久一线不卡| 亚洲欧洲日产国码二区| 中文在线免费一区三区高中清不卡| 日韩免费观看高清完整版| 69成人精品免费视频| 欧美日韩激情一区| 欧美少妇bbb| 欧美日韩一区中文字幕| 欧美视频一区在线| 欧美色视频一区| 欧美日韩国产色站一区二区三区| 在线观看日产精品|