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

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

?? diamond.cpp

?? 300個加解密的集合程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// diamond.cpp - modified by Wei Dai from:

/* diamond2.c - Encryption designed to exceed DES in security.
   This file and the Diamond2 and Diamond2 Lite Block Ciphers
   described herein are hereby dedicated to the Public Domain by the
   author and inventor, Michael Paul Johnson.  Feel free to use these
   for any purpose that is legally and morally right.  The names
   "Diamond2 Block Cipher" and "Diamond2 Lite Block Cipher" should only
   be used to describe the algorithms described in this file, to avoid
   confusion.

   Disclaimers:  the following comes with no warranty, expressed or
   implied.  You, the user, must determine the suitability of this
   information to your own uses.  You must also find out what legal
   requirements exist with respect to this data and programs using
   it, and comply with whatever valid requirements exist.
*/

#include "pch.h"
#include "diamond.h"

NAMESPACE_BEGIN(CryptoPP)

class Diamond2SboxMaker
{
public:
	Diamond2SboxMaker(const byte *external_key, unsigned int key_size,
					 unsigned int rounds, bool lite);

	void MakeSbox(byte *sbox, CipherDir direction);

private:
	unsigned int keyrand(unsigned int max_value, const byte *prevSbox);
	void makeonebox(byte *s, unsigned int i, unsigned int j);

	CRC32 crc;
	const byte *const key;
	const unsigned keysize;
	unsigned keyindex;
	const unsigned numrounds;
	const unsigned roundsize; // Number of bytes in one round of substitution boxes
	const unsigned blocksize;
};

Diamond2SboxMaker::Diamond2SboxMaker(const byte *external_key, unsigned int key_size, unsigned int rounds,
								   bool lite)
	: key(external_key),
	  keysize(key_size),
	  keyindex(0),
	  numrounds(rounds),
	  roundsize(lite ? 2048 : 4096),
	  blocksize(lite ? 8 : 16)
{
	assert((rounds * blocksize) <= 255);
}

// Returns uniformly distributed pseudorandom value based on key[], sized keysize
inline unsigned int Diamond2SboxMaker::keyrand(unsigned int max_value, const byte *prevSbox)
{
	if (!max_value) return 0;

	unsigned int mask, prandvalue, i;

	// Create a mask to get the minimum number of 
	// bits to cover the range 0 to max_value.
	for (i=max_value, mask=0; i > 0; i = i >> 1)
		mask = (mask << 1) | 1;

	assert(i==0);
	do
	{
		if (prevSbox)
			crc.UpdateByte(prevSbox[key[keyindex++]]);
		else
			crc.UpdateByte(key[keyindex++]);

		if (keyindex >= keysize)
		{
			keyindex = 0;   /* Recycle thru the key */
			crc.UpdateByte(byte(keysize));
			crc.UpdateByte(byte(keysize >> 8));
		}
		prandvalue = (unsigned int)~crc.GetCrc() & mask;
		if ((++i>97) && (prandvalue > max_value))   /* Don't loop forever. */
			prandvalue -= max_value;                /* Introduce negligible bias. */
	}
	while (prandvalue > max_value); /* Discard out of range values. */
	return prandvalue;
}

void Diamond2SboxMaker::makeonebox(byte *s, unsigned int i, unsigned int j)
{
	bool filled[256];
	byte *sbox = s + (roundsize*i) + (256*j);
	byte *prevSbox = (i||j) ? sbox-256 : 0;

	unsigned m;
	for (m = 0; m < 256; m++)   /* The filled array is used to make sure that */
		filled[m] = false;      /* each byte of the array is filled only once. */
	for (int n = 255; n >= 0 ; n--) /* n counts the number of bytes left to fill */
	{
		// pos is the position among the UNFILLED
		// components of the s array that the number n should be placed.
		unsigned pos = keyrand(n, prevSbox);   
		unsigned p=0;
		while (filled[p]) p++;
		for (m=0; m<pos; m++)
		{
			p++;
			while (filled[p]) p++;
		}
		assert(p<256);
		sbox[p] = n;
		filled[p] = true;
	}
}

void Diamond2SboxMaker::MakeSbox(byte *s, CipherDir direction)
{
	unsigned int i, j, k;

	for (i = 0; i < numrounds; i++)
		for (j = 0; j < blocksize; j++)
			makeonebox(s, i, j);

	if (direction==DECRYPTION)
	{
		SecByteBlock si(numrounds * roundsize);
		for (i = 0; i < numrounds; i++)
			for (j = 0; j < blocksize; j++)
				for (k = 0; k < 256; k++)
					*(si + (roundsize * i) + (256 * j) + *(s + (roundsize * i) + (256 * j) + k)) = k;
		memcpy(s, si, numrounds * roundsize);
	}
}

Diamond2Base::Diamond2Base(const byte *key, unsigned int key_size,
				 unsigned int rounds, CipherDir direction)
	: numrounds(rounds),
	  s(numrounds * ROUNDSIZE)
{
	Diamond2SboxMaker m(key, key_size, rounds, false);
	m.MakeSbox(s, direction);
}

inline void Diamond2Base::substitute(int round, byte *y) const
{
	const byte *sbox = s + (ROUNDSIZE*round);
	y[0] = sbox[0*256+y[0]];
	y[1] = sbox[1*256+y[1]];
	y[2] = sbox[2*256+y[2]];
	y[3] = sbox[3*256+y[3]];
	y[4] = sbox[4*256+y[4]];
	y[5] = sbox[5*256+y[5]];
	y[6] = sbox[6*256+y[6]];
	y[7] = sbox[7*256+y[7]];
	y[8] = sbox[8*256+y[8]];
	y[9] = sbox[9*256+y[9]];
	y[10] = sbox[10*256+y[10]];
	y[11] = sbox[11*256+y[11]];
	y[12] = sbox[12*256+y[12]];
	y[13] = sbox[13*256+y[13]];
	y[14] = sbox[14*256+y[14]];
	y[15] = sbox[15*256+y[15]];
}

#ifdef DIAMOND_USE_PERMTABLE

inline void Diamond2Base::permute(byte *a)
{
#ifdef IS_LITTLE_ENDIAN
	word32 temp0     = (a[0] | (word32(a[10])<<24)) & 0x80000001;
#else
	word32 temp0     = ((word32(a[0])<<24) | a[10]) & 0x01000080;
#endif
		   temp0    |=                      permtable[0][a[1]] |
					   permtable[1][a[2]] | permtable[2][a[3]] |
					   permtable[3][a[4]] | permtable[4][a[5]] |
					   permtable[5][a[6]] | permtable[6][a[7]] |
					   permtable[7][a[8]] | permtable[8][a[9]];

#ifdef IS_LITTLE_ENDIAN
	word32 temp1     = (a[4] | (word32(a[14])<<24)) & 0x80000001;
#else
	word32 temp1     = ((word32(a[4])<<24) | a[14]) & 0x01000080;
#endif
		   temp1    |=                      permtable[0][a[5]] |
					   permtable[1][a[6]] | permtable[2][a[7]] |
					   permtable[3][a[8]] | permtable[4][a[9]] |
					   permtable[5][a[10]] | permtable[6][a[11]] |
					   permtable[7][a[12]] | permtable[8][a[13]];

#ifdef IS_LITTLE_ENDIAN
	word32 temp2     = (a[8] | (word32(a[2])<<24)) & 0x80000001;
#else
	word32 temp2     = ((word32(a[8])<<24) | a[2]) & 0x01000080;
#endif
		   temp2    |=                       permtable[0][a[9]] |
					   permtable[1][a[10]] | permtable[2][a[11]] |
					   permtable[3][a[12]] | permtable[4][a[13]] |
					   permtable[5][a[14]] | permtable[6][a[15]] |
					   permtable[7][a[0]] | permtable[8][a[1]];

#ifdef IS_LITTLE_ENDIAN
	word32 temp3     = (a[12] | (word32(a[6])<<24)) & 0x80000001;
#else
	word32 temp3     = ((word32(a[12])<<24) | a[6]) & 0x01000080;
#endif
	((word32 *)a)[3] = temp3 |               permtable[0][a[13]] |
					   permtable[1][a[14]] | permtable[2][a[15]] |
					   permtable[3][a[0]] | permtable[4][a[1]] |
					   permtable[5][a[2]] | permtable[6][a[3]] |
					   permtable[7][a[4]] | permtable[8][a[5]];

	((word32 *)a)[0] = temp0;
	((word32 *)a)[1] = temp1;
	((word32 *)a)[2] = temp2;
}

inline void Diamond2Base::ipermute(byte *a)
{
#ifdef IS_LITTLE_ENDIAN
	word32 temp0     = (a[9] | (word32(a[3])<<24)) & 0x01000080;
#else
	word32 temp0     = ((word32(a[9])<<24) | a[3]) & 0x80000001;
#endif
		   temp0    |=                      ipermtable[0][a[2]] |
					   ipermtable[1][a[1]] | ipermtable[2][a[0]] |
					   ipermtable[3][a[15]] | ipermtable[4][a[14]] |
					   ipermtable[5][a[13]] | ipermtable[6][a[12]] |
					   ipermtable[7][a[11]] | ipermtable[8][a[10]];

#ifdef IS_LITTLE_ENDIAN
	word32 temp1     = (a[13] | (word32(a[7])<<24)) & 0x01000080;
#else
	word32 temp1     = ((word32(a[13])<<24) | a[7]) & 0x80000001;
#endif
		   temp1    |=                      ipermtable[0][a[6]] |
					   ipermtable[1][a[5]] | ipermtable[2][a[4]] |
					   ipermtable[3][a[3]] | ipermtable[4][a[2]] |
					   ipermtable[5][a[1]] | ipermtable[6][a[0]] |
					   ipermtable[7][a[15]] | ipermtable[8][a[14]];

#ifdef IS_LITTLE_ENDIAN
	word32 temp2     = (a[1] | (word32(a[11])<<24)) & 0x01000080;
#else
	word32 temp2     = ((word32(a[1])<<24) | a[11]) & 0x80000001;
#endif
		   temp2    |=                      ipermtable[0][a[10]] |
					   ipermtable[1][a[9]] | ipermtable[2][a[8]] |
					   ipermtable[3][a[7]] | ipermtable[4][a[6]] |
					   ipermtable[5][a[5]] | ipermtable[6][a[4]] |
					   ipermtable[7][a[3]] | ipermtable[8][a[2]];

#ifdef IS_LITTLE_ENDIAN
	word32 temp3     = (a[5] | (word32(a[15])<<24)) & 0x01000080;
#else
	word32 temp3     = ((word32(a[5])<<24) | a[15]) & 0x80000001;
#endif
	((word32 *)a)[3] = temp3 |               ipermtable[0][a[14]] |
					   ipermtable[1][a[13]] | ipermtable[2][a[12]] |
					   ipermtable[3][a[11]] | ipermtable[4][a[10]] |
					   ipermtable[5][a[9]] | ipermtable[6][a[8]] |
					   ipermtable[7][a[7]] | ipermtable[8][a[6]];

	((word32 *)a)[0] = temp0;
	((word32 *)a)[1] = temp1;
	((word32 *)a)[2] = temp2;
}

#else // DIAMOND_USE_PERMTABLE

inline void Diamond2Base::permute(byte *x)
{
	byte y[16];

	y[0] = (x[0] & 1) | (x[1] & 2) | (x[2] & 4) |
			(x[3] & 8) | (x[4] & 16) | (x[5] & 32) |
			(x[6] & 64) | (x[7] & 128);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲福利国产精品| 午夜欧美大尺度福利影院在线看 | 精品99一区二区三区| 欧美精品一级二级| 这里只有精品99re| 91精品国产综合久久久蜜臀图片 | 久久亚洲捆绑美女| 精品国产一区二区三区忘忧草| 欧美精品123区| 欧美一区二区二区| 日韩免费电影一区| 久久久精品蜜桃| 国产精品久久久久久久久快鸭| 久久久99精品免费观看| 国产精品久久久一本精品| ...xxx性欧美| 亚洲一卡二卡三卡四卡五卡| 亚洲综合精品自拍| 日韩成人午夜精品| 麻豆传媒一区二区三区| 国产精品亚洲午夜一区二区三区| 国产不卡在线一区| 欧洲精品中文字幕| 日韩视频一区二区三区在线播放| 精品国产1区二区| 中文字幕免费不卡| 亚洲一区二区三区视频在线 | 91猫先生在线| 欧美主播一区二区三区| 日韩一区二区在线看片| 337p日本欧洲亚洲大胆精品| 中文字幕一区二区三区视频| 天天操天天综合网| 国产精品一区二区三区乱码 | 欧洲视频一区二区| 精品国产在天天线2019| 亚洲色欲色欲www| 韩日精品视频一区| 欧美婷婷六月丁香综合色| 日韩午夜电影av| 18欧美乱大交hd1984| 日韩精品一二三四| 99视频一区二区| 精品国产乱码久久久久久蜜臀| 亚洲欧美激情小说另类| 国产精一区二区三区| 欧美另类一区二区三区| 国产精品女上位| 麻豆国产精品视频| 欧美三级一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲成人精品影院| 91香蕉视频污在线| 国产三级精品三级在线专区| 日韩高清在线一区| 色香蕉成人二区免费| 国产日产欧美精品一区二区三区| 日韩av不卡一区二区| 欧美综合一区二区三区| 欧美国产一区二区| 国产高清不卡一区| 久久日韩精品一区二区五区| 免费成人在线网站| 欧美一区二区网站| 亚洲电影一区二区三区| 色女孩综合影院| 1000部国产精品成人观看| 国产白丝精品91爽爽久久| 欧美大片顶级少妇| 久久精品国产网站| 欧美成人国产一区二区| 日本强好片久久久久久aaa| 欧美视频一区在线| 一区二区三区不卡在线观看| 99精品黄色片免费大全| 国产精品久久一级| av电影在线观看完整版一区二区| 国产精品剧情在线亚洲| 99久久国产综合精品麻豆| 中文字幕第一区| 97精品电影院| 亚洲卡通动漫在线| 色狠狠综合天天综合综合| 亚洲精品一二三区| 欧美综合一区二区三区| 性欧美大战久久久久久久久| 精品视频在线视频| 日日摸夜夜添夜夜添亚洲女人| 在线成人小视频| 精品一区二区三区在线视频| 精品国产乱码久久久久久免费| 激情丁香综合五月| 欧美国产日韩亚洲一区| 色妹子一区二区| 首页国产丝袜综合| 亚洲精品一区二区三区精华液| 久久99精品国产麻豆婷婷洗澡| 精品国产乱码久久久久久免费| 国产乱人伦偷精品视频不卡| 久久精品一区四区| 一本大道av伊人久久综合| 香蕉影视欧美成人| 久久日一线二线三线suv| 97精品国产97久久久久久久久久久久| 亚洲最大成人综合| 欧美成人精品二区三区99精品| 从欧美一区二区三区| 一区二区三区日本| 日韩一区二区免费高清| 99久久国产综合精品色伊| 日韩精品一二三| 国产精品久久久久影院亚瑟| 欧美精品亚洲二区| 成人久久久精品乱码一区二区三区| 亚洲自拍偷拍图区| 国产视频一区在线观看| 欧美精三区欧美精三区| 成人av在线资源网站| 秋霞电影网一区二区| 亚洲美女在线国产| 久久精品夜夜夜夜久久| 欧美日韩成人在线| aaa国产一区| 国产一区二区h| 亚洲成人av一区二区| 国产精品毛片a∨一区二区三区| 欧美一级理论片| 欧美视频中文字幕| av在线播放不卡| 国产成人午夜精品影院观看视频| 日韩专区在线视频| 亚洲色图都市小说| 国产免费成人在线视频| 欧美成人高清电影在线| 欧美乱妇一区二区三区不卡视频| 99久久国产综合精品色伊| 国产高清成人在线| 狠狠久久亚洲欧美| 精品无人区卡一卡二卡三乱码免费卡| 一区二区三区日韩精品| 亚洲男人天堂一区| 国产精品久久久久久久久久久免费看 | 欧美一区二区精品在线| 欧美优质美女网站| 99久久精品免费观看| 国产曰批免费观看久久久| 日产国产高清一区二区三区| 亚洲电影中文字幕在线观看| 亚洲美腿欧美偷拍| 亚洲私人影院在线观看| 日韩一区中文字幕| 亚洲免费视频中文字幕| 日韩理论在线观看| 亚洲少妇屁股交4| 亚洲天堂2014| 一区二区三区在线高清| 亚洲另类在线一区| 亚洲一区中文日韩| 五月激情丁香一区二区三区| 亚洲va天堂va国产va久| 天堂在线亚洲视频| 日韩成人一区二区| 精品综合免费视频观看| 国产一区二区美女| 国产aⅴ综合色| 99re这里只有精品视频首页| 色菇凉天天综合网| 欧美日本国产视频| 精品国产免费一区二区三区四区| 2019国产精品| 亚洲视频小说图片| 亚洲福利一二三区| 免费成人美女在线观看| 国产成人午夜高潮毛片| 94-欧美-setu| 69堂成人精品免费视频| 久久中文娱乐网| 亚洲视频在线观看一区| 视频一区二区三区在线| 国内精品久久久久影院色| 成人夜色视频网站在线观看| 色悠悠亚洲一区二区| 欧美一卡2卡3卡4卡| 国产免费成人在线视频| 亚洲成人久久影院| 国产精品18久久久久久久网站| 色婷婷一区二区三区四区| 日韩精品最新网址| 中文字幕佐山爱一区二区免费| 日韩高清在线观看| 成年人国产精品| 91精品国产91久久综合桃花 | 午夜精品久久久久久久99水蜜桃| 狠狠色综合播放一区二区| 不卡av在线免费观看| 日韩午夜激情电影| 一区二区在线观看视频在线观看| 久久精品72免费观看| 色哟哟国产精品免费观看| 国产亚洲成aⅴ人片在线观看|