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

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

?? rc6.cpp

?? VC實(shí)現(xiàn)的200種加密和解密的算法
?? CPP
字號(hào):
// rc6.cpp - written and placed in the public domain by Sean Woods
// based on Wei Dai's RC5 code.

#include "pch.h"
#include "rc6.h"

NAMESPACE_BEGIN(CryptoPP)

#ifdef _MSC_VER
#define ROTL(x,y) (_rotl((x), (unsigned int)(y)))
#define ROTR(x,y) (_rotr((x), (unsigned int)(y)))
#else
#define ROTL(x,y) (rotl((x), (unsigned int)(y) % (sizeof(RC6_WORD)*8)))
#define ROTR(x,y) (rotr((x), (unsigned int)(y) % (sizeof(RC6_WORD)*8)))
#endif

RC6Base::RC6Base(const byte *k, unsigned int keylen, unsigned int rounds)
	: r(rounds), sTable((2*r)+4)
{
	static const RC6_WORD MAGIC_P = 0xb7e15163L;    // magic constant P for wordsize
	static const RC6_WORD MAGIC_Q = 0x9e3779b9L;    // magic constant Q for wordsize
	static const int U=sizeof(RC6_WORD);

	const unsigned int c=(keylen-1)/U + 1;
	SecBlock<RC6_WORD> l(c);

	l[(keylen-1)/U] = 0;	// clear top word for when keylen%U != 0
	for (int i = (keylen-1) ; i >= 0; i--)
		l[i/U] = (l[i/U] << 8) + k[i];

	sTable[0] = MAGIC_P;
	for (unsigned j=1; j<sTable.size;j++)
		sTable[j] = sTable[j-1] + MAGIC_Q;

	RC6_WORD a=0, b=0;
	const unsigned n = 3*STDMAX(sTable.size,c);

	for (unsigned h=0; h < n; h++)
	{
		a = sTable[h % sTable.size] = ROTL((sTable[h % sTable.size] + a + b), 3);
		b = l[h % c] = ROTL((l[h % c] + a + b), (a+b));
	}
}

ANONYMOUS_NAMESPACE_BEGIN
// Fetch 8 bytes from user's buffer into "a", "b", "c", "d"
// in LITTLE-endian order
static inline void GETBLOCK(const byte *block, word32 &a, word32 &b, word32 &c, word32 &d)
{
#ifdef IS_LITTLE_ENDIAN
	a = *(word32 *)block;
	b = *(word32 *)(block+4);
	c = *(word32 *)(block+8);
	d = *(word32 *)(block+12);
#else
	a = byteReverse(*(word32 *)block);
	b = byteReverse(*(word32 *)(block+4));
	c = byteReverse(*(word32 *)(block+8));
	d = byteReverse(*(word32 *)(block+12));
#endif
}

// Put 8 bytes back into user's buffer in LITTLE-endian order
static inline void PUTBLOCK(byte *block, word32 a, word32 b, word32 c, word32 d)
{
#ifdef IS_LITTLE_ENDIAN
	*(word32 *)block = a;
	*(word32 *)(block+4) = b;
	*(word32 *)(block+8) = c;
	*(word32 *)(block+12) = d;
#else
	*(word32 *)block = byteReverse(a);
	*(word32 *)(block+4) = byteReverse(b);
	*(word32 *)(block+8) = byteReverse(c);
	*(word32 *)(block+12) = byteReverse(d);
#endif
}
NAMESPACE_END

void RC6Encryption::ProcessBlock(const byte *in, byte *out) const
{
	const RC6_WORD *sptr = sTable;
	RC6_WORD a, b, c, d, t, u;

	GETBLOCK(in, a, b, c, d);
	b += sptr[0];
	d += sptr[1];
	sptr += 2;

	for(unsigned i=0; i<r; i++)
	{
		t = ROTL(b*(2*b+1), 5);
		u = ROTL(d*(2*d+1), 5);
		a = ROTL(a^t,u) + sptr[0];
		c = ROTL(c^u,t) + sptr[1];
		t = a; a = b; b = c; c = d; d = t;
		sptr += 2;
	}

	a += sptr[0];
	c += sptr[1];

	PUTBLOCK(out, a, b, c, d);
}

void RC6Decryption::ProcessBlock(const byte *in, byte *out) const
{
	const RC6_WORD *sptr = sTable+sTable.size;
	RC6_WORD a, b, c, d, t, u;

	GETBLOCK(in, a, b, c, d);

	sptr -= 2;
	c -= sptr[1];
	a -= sptr[0];

	for (unsigned i=0; i < r; i++)
	{
		sptr -= 2;
		t = a; a = d; d = c; c = b; b = t;
		u = ROTL(d*(2*d+1), 5);
		t = ROTL(b*(2*b+1), 5);
		c = ROTR(c-sptr[1], t) ^ u;
		a = ROTR(a-sptr[0], u) ^ t;
	}

	sptr -= 2;
	d -= sTable[1];
	b -= sTable[0];

	PUTBLOCK(out, a, b, c, d);
}

NAMESPACE_END

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲综合成人网| 国产女人aaa级久久久级| 亚洲三级视频在线观看| 国产伦精品一区二区三区免费迷 | 在线免费视频一区二区| 亚洲美女区一区| 欧美日韩精品电影| 日本欧美一区二区三区乱码| 欧美变态凌虐bdsm| 国产一区二区三区四区五区美女 | 一本大道综合伊人精品热热| 亚洲最大色网站| 6080日韩午夜伦伦午夜伦| 免费日本视频一区| 久久精品日韩一区二区三区| 白白色亚洲国产精品| 亚洲免费观看高清完整版在线 | 日韩视频免费观看高清完整版| 久久精品国产99国产精品| 久久色中文字幕| 成人h动漫精品| 亚洲午夜免费电影| 欧美精品一区二区久久久| eeuss影院一区二区三区| 亚洲精品菠萝久久久久久久| 91精品国产综合久久香蕉的特点| 精品一区二区三区av| 1000部国产精品成人观看| 欧美日韩一区视频| 国产精选一区二区三区| 一区二区三区中文字幕精品精品| 欧美一区二区三区四区在线观看 | 免费成人av资源网| 国产欧美一区二区三区在线老狼| 色综合久久中文综合久久牛| 美女精品自拍一二三四| 国产精品每日更新| 91精品视频网| 91麻豆精东视频| 久久爱www久久做| 一区二区欧美精品| 久久久久久久网| 欧美老女人第四色| 国产69精品久久99不卡| 亚洲最大色网站| 中文字幕在线一区| 欧美xxxxx牲另类人与| 日本国产一区二区| 国产剧情在线观看一区二区| 视频一区免费在线观看| 亚洲婷婷在线视频| 国产亚洲一本大道中文在线| 欧美日韩国产综合久久| aaa亚洲精品| 国产美女精品在线| 秋霞电影网一区二区| 亚洲免费在线观看| 一区在线播放视频| 国产亚洲精品中文字幕| 亚洲欧美另类小说视频| 精品少妇一区二区三区日产乱码 | 亚洲精品乱码久久久久久久久| 亚洲精品一区二区三区在线观看| 在线免费视频一区二区| 色综合网色综合| av毛片久久久久**hd| 国产成人高清在线| 国产成人av一区| 国产一区二区三区视频在线播放| 日韩在线一区二区三区| 亚洲国产精品综合小说图片区| 中文字幕综合网| 国产精品美女视频| 国产视频911| 欧美激情一区二区三区四区| 欧美不卡在线视频| 日韩欧美专区在线| 777a∨成人精品桃花网| 欧美精选在线播放| 欧美在线免费播放| 欧美日韩免费视频| 欧美日韩午夜在线| 欧美三级日韩在线| 欧美日韩国产片| 欧美精品在线观看一区二区| 欧美三级韩国三级日本一级| 欧美在线一二三| 色狠狠av一区二区三区| 欧美午夜免费电影| 91精品国产色综合久久不卡蜜臀 | 欧美xfplay| 久久久久久久综合日本| 日本一区二区三区在线不卡| 中文字幕欧美一| 亚洲伦理在线精品| 午夜视频久久久久久| 三级在线观看一区二区 | 蜜臀精品一区二区三区在线观看| 久久久高清一区二区三区| 精品国产一区久久| 欧美mv日韩mv亚洲| 久久久影院官网| 国产精品女同互慰在线看| 亚洲人成在线播放网站岛国| 亚洲一线二线三线视频| 五月激情综合网| 国产伦精品一区二区三区免费| 粉嫩av一区二区三区在线播放| www.久久精品| 欧美精品日韩一区| 久久久综合九色合综国产精品| 国产精品美女久久久久久2018 | 开心九九激情九九欧美日韩精美视频电影| 麻豆国产91在线播放| 成人午夜视频在线观看| 色激情天天射综合网| 精品国产一区二区三区av性色| 日本一区二区三级电影在线观看 | 亚洲成人手机在线| 韩国中文字幕2020精品| 色诱视频网站一区| 日韩精品一区二区三区老鸭窝| 欧美国产精品一区二区三区| 亚洲一区免费在线观看| 久久9热精品视频| 91美女视频网站| 日韩欧美123| 亚洲综合色在线| 国产在线不卡一区| 欧美主播一区二区三区| 精品国产sm最大网站| 一区二区三区丝袜| 国产一区二区三区免费看| 欧美亚洲动漫制服丝袜| 国产婷婷色一区二区三区四区| 午夜欧美大尺度福利影院在线看| 国产一区二区三区综合| 精品国产亚洲一区二区三区在线观看| 看电视剧不卡顿的网站| 欧洲精品视频在线观看| 婷婷综合另类小说色区| 久久成人精品无人区| 色综合欧美在线| 国产亚洲欧美中文| 日韩中文字幕1| 在线免费观看成人短视频| 久久久www成人免费毛片麻豆| 天堂资源在线中文精品| 91猫先生在线| 中文字幕在线播放不卡一区| 国产福利一区在线| 欧美哺乳videos| 热久久国产精品| 69堂国产成人免费视频| 亚洲一区影音先锋| 色综合咪咪久久| 亚洲精品视频免费观看| 成人av在线影院| 国产精品天美传媒沈樵| 国产精品一区二区男女羞羞无遮挡| 欧美一区二区性放荡片| 日韩av电影免费观看高清完整版 | 国产精品久久久99| 国产剧情一区在线| 久久久久久久综合色一本| 久久成人麻豆午夜电影| 日韩精品中午字幕| 全部av―极品视觉盛宴亚洲| 欧美精品一级二级| 亚洲香肠在线观看| 欧美日韩免费观看一区三区| 亚洲第一狼人社区| 精品视频一区二区三区免费| 亚洲亚洲精品在线观看| 欧美在线观看你懂的| 亚洲图片欧美视频| 欧美日韩精品一区二区三区| 午夜电影网亚洲视频| 4438x成人网最大色成网站| 亚洲一二三四区不卡| 国产精品久久久久一区二区三区共| 精品久久久久久久久久久久久久久久久 | 欧美一区二区播放| 国产成人在线视频网址| 欧美极品美女视频| 4438x成人网最大色成网站| 久久精品在线观看| 亚洲成人精品一区二区| 欧美日韩国产在线观看| 青青国产91久久久久久| 欧美xxxx在线观看| 国产精品一区在线观看乱码| 国产精品免费av| 在线观看视频一区| 蜜桃久久久久久| 欧美激情在线一区二区三区| 色综合久久久久综合体桃花网| 亚洲大型综合色站| 2欧美一区二区三区在线观看视频| 激情久久五月天|