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

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

?? shark.cpp

?? 加密函數(shù)庫:包括多種加密解密算法,數(shù)字簽名,散列算法
?? CPP
字號(hào):
// shark.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"

#ifdef WORD64_AVAILABLE

#include "shark.h"
#include "misc.h"
#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], GF256::Element(a>>(56-8*j)))) << (56-8*i);
	return result;
}

void SHARK::Base::UncheckedSetKey(CipherDir dir, const byte *key, unsigned int keyLen, unsigned int rounds)
{
	AssertValidKeyLength(keyLen);
	AssertValidRounds(rounds);

	m_rounds = rounds;
	m_roundKeys.New(m_rounds+1);

	// concatenate key enought times to fill a
	for (unsigned int i=0; i<(m_rounds+1)*8; i++)
		((byte *)m_roundKeys.begin())[i] = key[i%keyLen];

	SHARK::Encryption e;
	e.InitForKeySetup();
	byte IV[8] = {0,0,0,0,0,0,0,0};
	CFB_Mode_ExternalCipher::Encryption cfb(e, IV);

	cfb.ProcessString((byte *)m_roundKeys.begin(), (m_rounds+1)*8);

	ConditionalByteReverse(BIG_ENDIAN_ORDER, m_roundKeys.begin(), m_roundKeys.begin(), (m_rounds+1)*8);

	m_roundKeys[m_rounds] = SHARKTransform(m_roundKeys[m_rounds]);

	if (dir == DECRYPTION)
	{
		unsigned int i;

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

		for (i=1; i<m_rounds; i++)
			m_roundKeys[i] = SHARKTransform(m_roundKeys[i]);
	}

#ifdef IS_LITTLE_ENDIAN
	m_roundKeys[0] = ByteReverse(m_roundKeys[0]);
	m_roundKeys[m_rounds] = ByteReverse(m_roundKeys[m_rounds]);
#endif
}

// construct an SHARK_Enc object with fixed round keys, to be used to initialize actual round keys
void SHARK::Enc::InitForKeySetup()
{
	m_rounds = DEFAULT_ROUNDS;
	m_roundKeys.New(DEFAULT_ROUNDS+1);

	for (unsigned int i=0; i<DEFAULT_ROUNDS; i++)
		m_roundKeys[i] = cbox[0][i];

	m_roundKeys[DEFAULT_ROUNDS] = SHARKTransform(cbox[0][DEFAULT_ROUNDS]);

#ifdef IS_LITTLE_ENDIAN
	m_roundKeys[0] = ByteReverse(m_roundKeys[0]);
	m_roundKeys[m_rounds] = ByteReverse(m_roundKeys[m_rounds]);
#endif
}

typedef word64 ArrayOf256Word64s[256];

template <const byte *sbox, const ArrayOf256Word64s *cbox>
struct SharkProcessAndXorBlock{		// VC60 workaround: problem with template functions
inline SharkProcessAndXorBlock(const word64 *roundKeys, unsigned int rounds, const byte *inBlock, const byte *xorBlock, byte *outBlock)
{
	word64 tmp = *(word64 *)inBlock ^ roundKeys[0];

	ByteOrder order = GetNativeByteOrder();
	tmp = cbox[0][GetByte(order, tmp, 0)] ^ cbox[1][GetByte(order, tmp, 1)] 
		^ cbox[2][GetByte(order, tmp, 2)] ^ cbox[3][GetByte(order, tmp, 3)] 
		^ cbox[4][GetByte(order, tmp, 4)] ^ cbox[5][GetByte(order, tmp, 5)] 
		^ cbox[6][GetByte(order, tmp, 6)] ^ cbox[7][GetByte(order, tmp, 7)]
		^ roundKeys[1];

	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];
	}

	PutBlock<byte, BigEndian>(xorBlock, outBlock)
		(sbox[GETBYTE(tmp, 7)])
		(sbox[GETBYTE(tmp, 6)])
		(sbox[GETBYTE(tmp, 5)])
		(sbox[GETBYTE(tmp, 4)])
		(sbox[GETBYTE(tmp, 3)])
		(sbox[GETBYTE(tmp, 2)])
		(sbox[GETBYTE(tmp, 1)])
		(sbox[GETBYTE(tmp, 0)]);

	*(word64 *)outBlock ^= roundKeys[rounds];
}};

void SHARK::Enc::ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const
{
	SharkProcessAndXorBlock<sbox, cbox>(m_roundKeys, m_rounds, inBlock, xorBlock, outBlock);
}

void SHARK::Dec::ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const
{
	SharkProcessAndXorBlock<sbox, cbox>(m_roundKeys, m_rounds, inBlock, xorBlock, outBlock);
}

NAMESPACE_END

#endif // WORD64_AVAILABLE

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
韩国精品免费视频| 亚洲成av人片在www色猫咪| 国产一区二区三区美女| 日韩免费电影一区| 久久成人羞羞网站| 欧美国产成人精品| jlzzjlzz亚洲日本少妇| 一区二区三区中文在线观看| 欧美在线视频日韩| 日韩国产精品久久久久久亚洲| 欧美一区二区三区四区视频| 精品亚洲免费视频| 国产精品天天摸av网| 色久综合一二码| 日韩在线卡一卡二| 久久久99精品免费观看不卡| 99精品视频在线播放观看| 一个色综合网站| 91麻豆精品国产91久久久更新时间| 激情久久五月天| 亚洲欧美综合在线精品| 欧美日韩在线不卡| 国产成人自拍高清视频在线免费播放| 国产精品国产三级国产| 欧美日韩国产综合一区二区三区 | 在线观看视频欧美| 奇米色777欧美一区二区| 久久久精品国产99久久精品芒果| 91在线看国产| 久久精品国产一区二区| 亚洲图片欧美激情| 欧美美女bb生活片| av在线不卡电影| 日韩av电影天堂| 亚洲人成网站色在线观看| 欧美一级片免费看| 99re热这里只有精品免费视频| 视频一区二区欧美| 日韩理论片网站| 精品国产乱码久久久久久1区2区| 91黄色免费观看| 国产又黄又大久久| 日韩一区欧美二区| 日韩美女久久久| 国产三级一区二区| 欧美一级片在线| 欧美日韩中文字幕一区| 国产99久久久国产精品免费看| 亚洲第一主播视频| 欧美国产丝袜视频| 日韩精品资源二区在线| 色国产精品一区在线观看| 国产美女在线精品| 五月天久久比比资源色| 亚洲人成影院在线观看| 国产喂奶挤奶一区二区三区| 日韩一区二区三区电影| 欧美人妇做爰xxxⅹ性高电影| 99精品视频在线观看| 国产91露脸合集magnet| 国模大尺度一区二区三区| 日本亚洲免费观看| 性欧美疯狂xxxxbbbb| 一区二区三区在线播放| 国产精品国产三级国产aⅴ无密码| 久久久三级国产网站| 精品国产免费人成电影在线观看四季| 欧美精品高清视频| 欧美精品少妇一区二区三区| 欧美无砖专区一中文字| 欧美亚洲尤物久久| 色老头久久综合| 在线视频亚洲一区| 91九色02白丝porn| 在线亚洲免费视频| 欧美视频中文字幕| 欧美欧美午夜aⅴ在线观看| 欧美日韩日本视频| 在线播放一区二区三区| 欧美老年两性高潮| 欧美高清性hdvideosex| 7777精品伊人久久久大香线蕉完整版 | 国产精品自在在线| 极品美女销魂一区二区三区免费| 全国精品久久少妇| 久久99精品国产91久久来源| 看国产成人h片视频| 国产永久精品大片wwwapp | 成人三级在线视频| 99久久免费精品高清特色大片| 北条麻妃国产九九精品视频| av网站免费线看精品| 一本大道久久a久久精品综合| 91美女视频网站| 欧美午夜精品一区| 日韩美女在线视频| 国产精品系列在线| 亚洲激情自拍视频| 另类成人小视频在线| 国产高清在线精品| 日本韩国一区二区三区视频| 欧美日高清视频| 国产午夜三级一区二区三| 国产精品成人网| 午夜日韩在线观看| 国产老肥熟一区二区三区| 91麻豆产精品久久久久久| 欧美日本不卡视频| 日本一区二区三区高清不卡| 亚洲一区二区成人在线观看| 日本不卡123| 大美女一区二区三区| 欧美日韩精品高清| 欧美—级在线免费片| 午夜久久久久久| 国产成人av一区二区三区在线观看| 成人免费精品视频| 欧美一区国产二区| 最新久久zyz资源站| 日本午夜精品视频在线观看| 99久久99久久免费精品蜜臀| 91麻豆精品国产| 亚洲图片激情小说| 国产在线精品不卡| 欧美人与z0zoxxxx视频| 1区2区3区国产精品| 日本不卡在线视频| 91网址在线看| 国产亚洲欧美中文| 日本一区中文字幕| 色噜噜狠狠成人中文综合| 2020日本不卡一区二区视频| 亚洲电影第三页| 91在线一区二区三区| 精品国产一区二区三区久久影院| 亚洲一区二区综合| 99久久婷婷国产精品综合| 精品噜噜噜噜久久久久久久久试看| 亚洲乱码日产精品bd| 国产成人免费高清| 精品毛片乱码1区2区3区| 亚洲大尺度视频在线观看| 99久久国产免费看| 国产视频一区二区三区在线观看 | 亚洲一二三区不卡| 成人午夜免费视频| 精品91自产拍在线观看一区| 午夜久久电影网| 日本韩国欧美国产| 亚洲视频香蕉人妖| 成人午夜激情影院| 国产拍揄自揄精品视频麻豆| 卡一卡二国产精品| 91麻豆精品国产91久久久 | 精品国产91洋老外米糕| 日韩综合一区二区| 欧美日韩三级一区| 亚洲一级二级在线| 欧美日韩国产综合久久| 亚洲一区二区三区四区在线| 91麻豆成人久久精品二区三区| 国产精品日产欧美久久久久| 国产成人精品亚洲777人妖| 久久午夜老司机| 国产露脸91国语对白| 久久久美女毛片| 国产超碰在线一区| 亚洲国产精品ⅴa在线观看| 福利电影一区二区| 中文字幕永久在线不卡| 91网站最新地址| 夜色激情一区二区| 欧美日韩成人高清| 免费看欧美女人艹b| 精品理论电影在线观看| 国产高清精品网站| 国产精品亲子伦对白| 91蜜桃视频在线| 亚洲国产日韩综合久久精品| 欧美日韩和欧美的一区二区| 奇米精品一区二区三区在线观看一 | 91欧美激情一区二区三区成人| 亚洲欧美一区二区三区久本道91| 在线精品国精品国产尤物884a| 亚洲午夜精品在线| 91精品国产一区二区三区蜜臀| 久久精品免费看| 国产欧美一区二区三区鸳鸯浴| 99久久夜色精品国产网站| 亚洲国产一区二区a毛片| 日韩一二三区不卡| 国产精品99久久久久久似苏梦涵| 中文字幕不卡三区| 精品视频在线看| 久久99精品国产麻豆婷婷洗澡| 国产女人aaa级久久久级| 一本一道综合狠狠老| 男女性色大片免费观看一区二区 | 久久九九久久九九| 色成年激情久久综合|