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

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

?? default.cpp

?? 300多種解密算法C語言 語言
?? CPP
字號:
// default.cpp - written and placed in the public domain by Wei Dai

#include "pch.h"
#include "default.h"
#include "cbc.h"
#include <time.h>
#include <memory>

NAMESPACE_BEGIN(CryptoPP)

static const unsigned int MASH_ITERATIONS = 200;
static const unsigned int SALTLENGTH = 8;
static const unsigned int BLOCKSIZE = Default_ECB_Encryption::BLOCKSIZE;
static const unsigned int KEYLENGTH = Default_ECB_Encryption::KEYLENGTH;

// The purpose of this function Mash() is to take an arbitrary length input
// string and *deterministicly* produce an arbitrary length output string such
// that (1) it looks random, (2) no information about the input is
// deducible from it, and (3) it contains as much entropy as it can hold, or
// the amount of entropy in the input string, whichever is smaller.

void Mash(byte *const in, word16 inLen, byte *out, word16 outLen, int iterations)
{
	unsigned int bufSize = (outLen-1+DefaultHashModule::DIGESTSIZE-((outLen-1)%DefaultHashModule::DIGESTSIZE));

	// ASSERT: bufSize == (the smallest multiple of DIGESTSIZE that is >= outLen)

	byte b[2];
	SecByteBlock buf(bufSize);
	SecByteBlock outBuf(bufSize);
	DefaultHashModule hash;

	unsigned int i;
	for(i=0; i<outLen; i+=DefaultHashModule::DIGESTSIZE)
	{
		b[0] = (byte) i >> 8;
		b[1] = (byte) i;
		hash.Update(b, 2);
		hash.Update(in, inLen);
		hash.Final(outBuf+i);
	}

	while (iterations-- > 1)
	{
		memcpy(buf, outBuf, bufSize);
		for (i=0; i<bufSize; i+=DefaultHashModule::DIGESTSIZE)
		{
			b[0] = (byte) i >> 8;
			b[1] = (byte) i;
			hash.Update(b, 2);
			hash.Update(buf, bufSize);
			hash.Final(outBuf+i);
		}
	}

	memcpy(out, outBuf, outLen);
}

static void GenerateKeyIV(const char *passphrase, const byte *salt, unsigned int saltLength, byte *key, byte *IV)
{
	unsigned int passphraseLength = strlen(passphrase);
	SecByteBlock temp(passphraseLength+saltLength);
	memcpy(temp, passphrase, passphraseLength);
	memcpy(temp+passphraseLength, salt, saltLength);
	SecByteBlock keyIV(KEYLENGTH+BLOCKSIZE);
	Mash(temp, passphraseLength + saltLength, keyIV, KEYLENGTH+BLOCKSIZE, MASH_ITERATIONS);
	memcpy(key, keyIV, KEYLENGTH);
	memcpy(IV, keyIV+KEYLENGTH, BLOCKSIZE);
}

// ********************************************************

DefaultEncryptor::DefaultEncryptor(const char *passphrase, BufferedTransformation *outQ)
	: Filter(outQ)
{
	assert(SALTLENGTH <= DefaultHashModule::DIGESTSIZE);
	assert(BLOCKSIZE <= DefaultHashModule::DIGESTSIZE);

	SecByteBlock salt(DefaultHashModule::DIGESTSIZE), keyCheck(DefaultHashModule::DIGESTSIZE);
	DefaultHashModule hash;

	// use hash(passphrase | time | clock) as salt
	hash.Update((byte *)passphrase, strlen(passphrase));
	time_t t=time(0);
	hash.Update((byte *)&t, sizeof(t));
	clock_t c=clock();
	hash.Update((byte *)&c, sizeof(c));
	hash.Final(salt);

	// use hash(passphrase | salt) as key check
	hash.Update((byte *)passphrase, strlen(passphrase));
	hash.Update(salt, SALTLENGTH);
	hash.Final(keyCheck);

	outQueue->Put(salt, SALTLENGTH);

	// mash passphrase and salt together into key and IV
	SecByteBlock key(KEYLENGTH);
	SecByteBlock IV(BLOCKSIZE);
	GenerateKeyIV(passphrase, salt, SALTLENGTH, key, IV);

	cipher.reset(new Default_ECB_Encryption(key));
	outQueue.reset(new CBCPaddedEncryptor(*cipher, IV, outQueue.release()));

	outQueue->Put(keyCheck, BLOCKSIZE);
}

void DefaultEncryptor::Put(byte inByte)
{
	outQueue->Put(inByte);
}

void DefaultEncryptor::Put(const byte *inString, unsigned int length)
{
	outQueue->Put(inString, length);
}

// ********************************************************

DefaultDecryptor::DefaultDecryptor(const char *p, BufferedTransformation *outQueue)
	: Filter(outQueue),
	  passphrase(strlen(p)+1),
	  salt(SALTLENGTH),
	  keyCheck(BLOCKSIZE)
{
	strcpy(passphrase, p);
	state = WAITING_FOR_KEYCHECK;
	count = 0;
}

void DefaultDecryptor::Put(byte inByte)
{
	if (state==WAITING_FOR_KEYCHECK)
	{
		assert (count < SALTLENGTH+BLOCKSIZE);

		if (count < SALTLENGTH)
			salt[count]=inByte;
		else
			keyCheck[count-SALTLENGTH]=inByte;

		if (++count == SALTLENGTH+BLOCKSIZE)
			CheckKey();
	}
	else
		outQueue->Put(inByte);
}

void DefaultDecryptor::Put(const byte *inString, unsigned int length)
{
	while (state==WAITING_FOR_KEYCHECK && length)
	{
		Put(*inString++);
		length--;
	}

	if (length)
		outQueue->Put(inString, length);
}

void DefaultDecryptor::CheckKey()
{
	SecByteBlock check(STDMAX((unsigned int)2*BLOCKSIZE, (unsigned int)DefaultHashModule::DIGESTSIZE));

	DefaultHashModule hash;
	hash.Update((byte *)passphrase.ptr, strlen(passphrase));
	hash.Update(salt, SALTLENGTH);
	hash.Final(check);

	SecByteBlock key(KEYLENGTH);
	SecByteBlock IV(BLOCKSIZE);
	GenerateKeyIV(passphrase, salt, SALTLENGTH, key, IV);

	cipher.reset(new Default_ECB_Decryption(key));
	std::auto_ptr<CBCPaddedDecryptor> decryptor(new CBCPaddedDecryptor(*cipher, IV));

	decryptor->Put(keyCheck, BLOCKSIZE);
	decryptor->ProcessBuf();
	decryptor->Get(check+BLOCKSIZE, BLOCKSIZE);

	if (memcmp(check, check+BLOCKSIZE, BLOCKSIZE))
		state = KEY_BAD;
	else
		state = KEY_GOOD;

	decryptor->Attach(outQueue.release());
	outQueue.reset(decryptor.release());
}

NAMESPACE_END

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电影免费观看高清完整版| 99久久国产综合精品色伊| 欧美日韩日日骚| 一区二区三区成人| 91豆麻精品91久久久久久| 亚洲欧美aⅴ...| 欧美在线观看一区二区| 亚洲午夜久久久久| 欧美一级黄色片| 国产伦精品一区二区三区在线观看| 精品国产免费久久| 国产mv日韩mv欧美| 国产精品午夜春色av| 99九九99九九九视频精品| 自拍偷自拍亚洲精品播放| 欧洲精品一区二区| 人人超碰91尤物精品国产| 精品国产制服丝袜高跟| 成人污污视频在线观看| 一区二区三区色| 7777精品伊人久久久大香线蕉| 韩国欧美国产一区| 亚洲精品亚洲人成人网| 91精品国产色综合久久不卡电影| 久草中文综合在线| 国产精品久久二区二区| 9191久久久久久久久久久| 国产麻豆精品95视频| 一区二区三区日本| 久久久午夜精品理论片中文字幕| 在线视频国产一区| 国产一区二区剧情av在线| 国产精品久久三| 91麻豆精品91久久久久同性| 国产一区二区三区黄视频 | 欧美性色综合网| 看国产成人h片视频| 国产精品国产三级国产普通话三级| 欧美在线观看禁18| 国产成人午夜99999| 亚洲成人动漫一区| 欧美激情一区二区三区不卡 | 成人在线综合网站| 亚洲一区二区三区在线看 | 国产精品国产三级国产普通话99 | 97久久超碰国产精品| 天堂av在线一区| 欧美激情一区二区三区蜜桃视频| 欧美日韩亚洲另类| 成人h动漫精品一区二| 免费观看在线色综合| 亚洲乱码国产乱码精品精的特点 | 日本一区二区三区国色天香| 欧美日韩一本到| 99免费精品视频| 国产一区二区三区免费播放| 日本午夜精品视频在线观看| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 亚洲一区中文日韩| 中文在线免费一区三区高中清不卡| 欧美精品久久天天躁| 91视频免费看| 国产91对白在线观看九色| 九九九精品视频| 天天综合网 天天综合色| 亚洲欧美经典视频| 中文字幕一区二区三区在线不卡| 日韩美女一区二区三区四区| 欧美福利视频导航| 色哟哟一区二区在线观看 | 亚洲男人的天堂网| 成人欧美一区二区三区视频网页| 国产欧美视频在线观看| 欧美大片日本大片免费观看| 欧美美女一区二区在线观看| 欧美日韩免费高清一区色橹橹 | 亚洲国产美女搞黄色| 亚洲欧洲日产国产综合网| 久久精品亚洲一区二区三区浴池| 精品日本一线二线三线不卡| 欧美一二三区精品| 欧美一区二区三区人| 宅男在线国产精品| 在线播放91灌醉迷j高跟美女| 欧美猛男gaygay网站| 538在线一区二区精品国产| 欧美乱妇20p| 777a∨成人精品桃花网| 欧美一区二区在线视频| 宅男在线国产精品| 精品国产一区二区精华| 国产拍欧美日韩视频二区| 久久久久久亚洲综合| 日本一区二区久久| 亚洲日本va午夜在线电影| 一个色在线综合| 亚洲一二三专区| 日韩精品乱码av一区二区| 久久99国产乱子伦精品免费| 国产精品2024| 色综合久久88色综合天天免费| 91国产成人在线| 欧美一区二区三区四区五区| 久久久91精品国产一区二区精品| 中文字幕第一区二区| 亚洲精品日产精品乱码不卡| 天天操天天综合网| 国产一区二区精品久久91| 99久久国产免费看| 欧美一区二区播放| 亚洲欧美综合在线精品| 亚洲国产精品天堂| 国产精品一区二区久激情瑜伽| eeuss鲁片一区二区三区在线观看| 色94色欧美sute亚洲线路一久| 欧美久久久一区| 国产日韩亚洲欧美综合| 亚洲中国最大av网站| 极品少妇xxxx精品少妇| 91在线免费看| 欧美不卡在线视频| 亚洲乱码国产乱码精品精小说| 久久成人免费电影| 色香蕉久久蜜桃| 26uuu精品一区二区在线观看| 亚洲综合精品自拍| 国产成人在线观看| 欧美日韩国产一区| 国产女主播视频一区二区| 日韩精品电影在线观看| 99在线热播精品免费| 欧美xxxx老人做受| 亚洲第一综合色| 成人app软件下载大全免费| 337p亚洲精品色噜噜狠狠| 国产精品久久二区二区| 老司机精品视频在线| 一本大道av一区二区在线播放| 久久综合成人精品亚洲另类欧美| 亚洲色图视频免费播放| 国产最新精品免费| 91精品欧美一区二区三区综合在| 最新欧美精品一区二区三区| 久久成人精品无人区| 欧美日精品一区视频| 中文字幕综合网| 国产mv日韩mv欧美| 精品国产凹凸成av人导航| 亚洲3atv精品一区二区三区| av在线不卡电影| 久久久亚洲精品石原莉奈| 另类小说一区二区三区| 欧美日韩久久久一区| 亚洲一二三区在线观看| av不卡在线观看| 国产精品色婷婷久久58| 国产一区二区三区久久久| 精品少妇一区二区三区日产乱码 | 久久97超碰国产精品超碰| 69堂成人精品免费视频| 亚洲www啪成人一区二区麻豆 | 欧美日高清视频| 亚洲自拍偷拍网站| 色婷婷一区二区| 一区二区三区在线视频免费观看| 不卡电影免费在线播放一区| 国产精品欧美经典| 成人精品在线视频观看| 久久久夜色精品亚洲| 国产99久久久国产精品| 久久久不卡网国产精品一区| 国产精品一区免费视频| 久久久久久综合| www.欧美色图| 一区二区三区在线影院| 欧美三级蜜桃2在线观看| 石原莉奈一区二区三区在线观看| 91精品国产综合久久精品| 美洲天堂一区二卡三卡四卡视频| 欧美一级在线免费| 国产伦精品一区二区三区视频青涩| 久久人人爽爽爽人久久久| 国产成人99久久亚洲综合精品| 国产精品毛片a∨一区二区三区| 99精品国产热久久91蜜凸| 一区二区三区四区高清精品免费观看 | 国产成人免费视频一区| 国产欧美日韩三级| 99综合电影在线视频| 亚洲午夜久久久久久久久电影院| 欧美日韩国产天堂| 久久电影网电视剧免费观看| 久久精品日韩一区二区三区| 成a人片亚洲日本久久| 一二三区精品视频| 欧美一区二区在线视频| 国产精品77777竹菊影视小说| 亚洲视频一区二区在线| 欧美片网站yy| 成人一级视频在线观看|