⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 validat1.cpp

📁 lots Elliptic curve cryptography codes. Use Visual c++ to compile
💻 CPP
📖 第 1 页 / 共 4 页
字号:
	fail = memcmp(Output1, Key1, sizeof(Key1)) != 0;	cout << (fail ? "FAILED" : "passed") << "    Test 1" << endl;	pass = pass && !fail;	arc4.reset(new Weak::ARC4(Key2, sizeof(Key2)));	for (i=0, fail=false; i<sizeof(Input2); i++)		if (arc4->ProcessByte(Input2[i]) != Output2[i])			fail = true;	cout << (fail ? "FAILED" : "passed") << "    Test 2" << endl;	pass = pass && !fail;	arc4.reset(new Weak::ARC4(Key3, sizeof(Key3)));	for (i=0, fail=false; i<sizeof(Input3); i++)		if (arc4->ProcessByte(Input3[i]) != Output3[i])			fail = true;	cout << (fail ? "FAILED" : "passed") << "    Test 3" << endl;	pass = pass && !fail;	arc4.reset(new Weak::ARC4(Key4, sizeof(Key4)));	for (i=0, fail=false; i<sizeof(Input4); i++)		if (arc4->ProcessByte(Input4[i]) != Output4[i])			fail = true;	cout << (fail ? "FAILED" : "passed") << "    Test 4" << endl;	pass = pass && !fail;	return pass;}bool ValidateRC5(){	cout << "\nRC5 validation suite running...\n\n";	FileSource valdata("TestData/rc5val.dat", true, new HexDecoder);	return BlockTransformationTest(VariableRoundsCipherFactory<RC5Encryption, RC5Decryption>(16, 12), valdata);}bool ValidateRC6(){	cout << "\nRC6 validation suite running...\n\n";	FileSource valdata("TestData/rc6val.dat", true, new HexDecoder);	bool pass = true;	pass = BlockTransformationTest(FixedRoundsCipherFactory<RC6Encryption, RC6Decryption>(16), valdata, 2) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<RC6Encryption, RC6Decryption>(24), valdata, 2) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<RC6Encryption, RC6Decryption>(32), valdata, 2) && pass;	return pass;}bool ValidateMARS(){	cout << "\nMARS validation suite running...\n\n";	FileSource valdata("TestData/marsval.dat", true, new HexDecoder);	bool pass = true;	pass = BlockTransformationTest(FixedRoundsCipherFactory<MARSEncryption, MARSDecryption>(16), valdata, 4) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<MARSEncryption, MARSDecryption>(24), valdata, 3) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<MARSEncryption, MARSDecryption>(32), valdata, 2) && pass;	return pass;}bool ValidateRijndael(){	cout << "\nRijndael (AES) validation suite running...\n\n";	FileSource valdata("TestData/rijndael.dat", true, new HexDecoder);	bool pass = true;	pass = BlockTransformationTest(FixedRoundsCipherFactory<RijndaelEncryption, RijndaelDecryption>(16), valdata, 4) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<RijndaelEncryption, RijndaelDecryption>(24), valdata, 3) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<RijndaelEncryption, RijndaelDecryption>(32), valdata, 2) && pass;	pass = RunTestDataFile("TestVectors/aes.txt") && pass;	return pass;}bool ValidateTwofish(){	cout << "\nTwofish validation suite running...\n\n";	FileSource valdata("TestData/twofishv.dat", true, new HexDecoder);	bool pass = true;	pass = BlockTransformationTest(FixedRoundsCipherFactory<TwofishEncryption, TwofishDecryption>(16), valdata, 4) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<TwofishEncryption, TwofishDecryption>(24), valdata, 3) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<TwofishEncryption, TwofishDecryption>(32), valdata, 2) && pass;	return pass;}bool ValidateSerpent(){	cout << "\nSerpent validation suite running...\n\n";	FileSource valdata("TestData/serpentv.dat", true, new HexDecoder);	bool pass = true;	pass = BlockTransformationTest(FixedRoundsCipherFactory<SerpentEncryption, SerpentDecryption>(16), valdata, 4) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<SerpentEncryption, SerpentDecryption>(24), valdata, 3) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<SerpentEncryption, SerpentDecryption>(32), valdata, 2) && pass;	return pass;}bool ValidateBlowfish(){	cout << "\nBlowfish validation suite running...\n\n";	HexEncoder output(new FileSink(cout));	const char *key[]={"abcdefghijklmnopqrstuvwxyz", "Who is John Galt?"};	byte *plain[]={(byte *)"BLOWFISH", (byte *)"\xfe\xdc\xba\x98\x76\x54\x32\x10"};	byte *cipher[]={(byte *)"\x32\x4e\xd0\xfe\xf4\x13\xa2\x03", (byte *)"\xcc\x91\x73\x2b\x80\x22\xf6\x84"};	byte out[8], outplain[8];	bool pass=true, fail;	for (int i=0; i<2; i++)	{		ECB_Mode<Blowfish>::Encryption enc((byte *)key[i], strlen(key[i]));		enc.ProcessData(out, plain[i], 8);		fail = memcmp(out, cipher[i], 8) != 0;		ECB_Mode<Blowfish>::Decryption dec((byte *)key[i], strlen(key[i]));		dec.ProcessData(outplain, cipher[i], 8);		fail = fail || memcmp(outplain, plain[i], 8);		pass = pass && !fail;		cout << (fail ? "FAILED    " : "passed    ");		cout << '\"' << key[i] << '\"';		for (int j=0; j<(signed int)(30-strlen(key[i])); j++)			cout << ' ';		output.Put(outplain, 8);		cout << "  ";		output.Put(out, 8);		cout << endl;	}	return pass;}bool ValidateThreeWay(){	cout << "\n3-WAY validation suite running...\n\n";	FileSource valdata("TestData/3wayval.dat", true, new HexDecoder);	return BlockTransformationTest(FixedRoundsCipherFactory<ThreeWayEncryption, ThreeWayDecryption>(), valdata);}bool ValidateGOST(){	cout << "\nGOST validation suite running...\n\n";	FileSource valdata("TestData/gostval.dat", true, new HexDecoder);	return BlockTransformationTest(FixedRoundsCipherFactory<GOSTEncryption, GOSTDecryption>(), valdata);}bool ValidateSHARK(){	cout << "\nSHARK validation suite running...\n\n";	FileSource valdata("TestData/sharkval.dat", true, new HexDecoder);	return BlockTransformationTest(FixedRoundsCipherFactory<SHARKEncryption, SHARKDecryption>(), valdata);}bool ValidateCAST(){	bool pass = true;	cout << "\nCAST-128 validation suite running...\n\n";	FileSource val128("TestData/cast128v.dat", true, new HexDecoder);	pass = BlockTransformationTest(FixedRoundsCipherFactory<CAST128Encryption, CAST128Decryption>(16), val128, 1) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<CAST128Encryption, CAST128Decryption>(10), val128, 1) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<CAST128Encryption, CAST128Decryption>(5), val128, 1) && pass;	cout << "\nCAST-256 validation suite running...\n\n";	FileSource val256("TestData/cast256v.dat", true, new HexDecoder);	pass = BlockTransformationTest(FixedRoundsCipherFactory<CAST256Encryption, CAST256Decryption>(16), val256, 1) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<CAST256Encryption, CAST256Decryption>(24), val256, 1) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<CAST256Encryption, CAST256Decryption>(32), val256, 1) && pass;	return pass;}bool ValidateSquare(){	cout << "\nSquare validation suite running...\n\n";	FileSource valdata("TestData/squareva.dat", true, new HexDecoder);	return BlockTransformationTest(FixedRoundsCipherFactory<SquareEncryption, SquareDecryption>(), valdata);}bool ValidateSKIPJACK(){	cout << "\nSKIPJACK validation suite running...\n\n";	FileSource valdata("TestData/skipjack.dat", true, new HexDecoder);	return BlockTransformationTest(FixedRoundsCipherFactory<SKIPJACKEncryption, SKIPJACKDecryption>(), valdata);}bool ValidateSEAL(){	byte input[] = {0x37,0xa0,0x05,0x95,0x9b,0x84,0xc4,0x9c,0xa4,0xbe,0x1e,0x05,0x06,0x73,0x53,0x0f,0x5f,0xb0,0x97,0xfd,0xf6,0xa1,0x3f,0xbd,0x6c,0x2c,0xde,0xcd,0x81,0xfd,0xee,0x7c};	byte output[32];	byte key[] = {0x67, 0x45, 0x23, 0x01, 0xef, 0xcd, 0xab, 0x89, 0x98, 0xba, 0xdc, 0xfe, 0x10, 0x32, 0x54, 0x76, 0xc3, 0xd2, 0xe1, 0xf0};	byte iv[] = {0x01, 0x35, 0x77, 0xaf};	cout << "\nSEAL validation suite running...\n\n";	SEAL<>::Encryption seal(key, sizeof(key), iv);	unsigned int size = sizeof(input);	bool pass = true;	memset(output, 1, size);	seal.ProcessString(output, input, size);	for (unsigned int i=0; i<size; i++)		if (output[i] != 0)			pass = false;	seal.Seek(1);	output[1] = seal.ProcessByte(output[1]);	seal.ProcessString(output+2, size-2);	pass = pass && memcmp(output+1, input+1, size-1) == 0;	cout << (pass ? "passed" : "FAILED") << endl;	return pass;}bool ValidateBaseCode(){	bool pass = true, fail;	byte data[255];	for (unsigned int i=0; i<255; i++)		data[i] = i;	const char *hexEncoded = "000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F2021222324252627""28292A2B2C2D2E2F303132333435363738393A3B3C3D3E3F404142434445464748494A4B4C4D4E4F""505152535455565758595A5B5C5D5E5F606162636465666768696A6B6C6D6E6F7071727374757677""78797A7B7C7D7E7F808182838485868788898A8B8C8D8E8F909192939495969798999A9B9C9D9E9F""A0A1A2A3A4A5A6A7A8A9AAABACADAEAFB0B1B2B3B4B5B6B7B8B9BABBBCBDBEBFC0C1C2C3C4C5C6C7""C8C9CACBCCCDCECFD0D1D2D3D4D5D6D7D8D9DADBDCDDDEDFE0E1E2E3E4E5E6E7E8E9EAEBECEDEEEF""F0F1F2F3F4F5F6F7F8F9FAFBFCFDFE";	const char *base32Encoded = "AAASEA2EAWDAQCAJBIFS2DIQB6IBCESVCSKTNF22DEPBYHA7D2RUAIJCENUCKJTHFAWUWK3NFWZC8NBT""GI3VIPJYG66DUQT5HS8V6R4AIFBEGTCFI3DWSUKKJPGE4VURKBIXEW4WKXMFQYC3MJPX2ZK8M7SGC2VD""NTUYN35IPFXGY5DPP3ZZA6MUQP4HK7VZRB6ZW856RX9H9AEBSKB2JBNGS8EIVCWMTUG27D6SUGJJHFEX""U4M3TGN4VQQJ5HW9WCS4FI7EWYVKRKFJXKX43MPQX82MDNXVYU45PP72ZG7MZRF7Z496BSQC2RCNMTYH""3DE6XU8N3ZHN9WGT4MJ7JXQY49NPVYY55VQ77Z9A6HTQH3HF65V8T4RK7RYQ55ZR8D29F69W8Z5RR8H3""9M7939R8";	const char *base64AndHexEncoded = "41414543417751464267634943516F4C4441304F4478415245684D554652595847426B6147787764""486838674953496A4A43556D4A7967704B6973734C5334764D4445794D7A51310A4E6A63344F546F""375044302B50304242516B4E4552555A4853456C4B5330784E546B395155564A5456465657563168""5A576C746358563566594746695932526C5A6D646F615770720A6247317562334278636E4E306458""5A3365486C3665337839666E2B4167594B44684957476834694A696F754D6A5936506B4A47536B35""53566C7065596D5A71626E4A32656E3643680A6F714F6B7061616E714B6D717136797472712B7773""624B7A744C573274376935757275387662362F774D484377385446787366497963724C7A4D334F7A""39445230745055316462580A324E6E6132397A6433742F6734654C6A354F586D352B6A7036757673""3765377638504879382F5431397666342B6672372F50332B0A";	cout << "\nBase64, base32 and hex coding validation suite running...\n\n";	fail = !TestFilter(HexEncoder().Ref(), data, 255, (const byte *)hexEncoded, strlen(hexEncoded));	cout << (fail ? "FAILED    " : "passed    ");	cout << "Hex Encoding\n";	pass = pass && !fail;	fail = !TestFilter(HexDecoder().Ref(), (const byte *)hexEncoded, strlen(hexEncoded), data, 255);	cout << (fail ? "FAILED    " : "passed    ");	cout << "Hex Decoding\n";	pass = pass && !fail;	fail = !TestFilter(Base32Encoder().Ref(), data, 255, (const byte *)base32Encoded, strlen(base32Encoded));	cout << (fail ? "FAILED    " : "passed    ");	cout << "Base32 Encoding\n";	pass = pass && !fail;	fail = !TestFilter(Base32Decoder().Ref(), (const byte *)base32Encoded, strlen(base32Encoded), data, 255);	cout << (fail ? "FAILED    " : "passed    ");	cout << "Base32 Decoding\n";	pass = pass && !fail;	fail = !TestFilter(Base64Encoder(new HexEncoder).Ref(), data, 255, (const byte *)base64AndHexEncoded, strlen(base64AndHexEncoded));	cout << (fail ? "FAILED    " : "passed    ");	cout << "Base64 Encoding\n";	pass = pass && !fail;	fail = !TestFilter(HexDecoder(new Base64Decoder).Ref(), (const byte *)base64AndHexEncoded, strlen(base64AndHexEncoded), data, 255);	cout << (fail ? "FAILED    " : "passed    ");	cout << "Base64 Decoding\n";	pass = pass && !fail;	return pass;}bool ValidateSHACAL2(){	cout << "\nSHACAL-2 validation suite running...\n\n";	bool pass = true;	FileSource valdata("TestData/shacal2v.dat", true, new HexDecoder);	pass = BlockTransformationTest(FixedRoundsCipherFactory<SHACAL2Encryption, SHACAL2Decryption>(16), valdata, 4) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<SHACAL2Encryption, SHACAL2Decryption>(64), valdata, 10) && pass;	return pass;}bool ValidateCamellia(){	cout << "\nCamellia validation suite running...\n\n";	bool pass = true;	FileSource valdata("TestData/camellia.dat", true, new HexDecoder);	pass = BlockTransformationTest(FixedRoundsCipherFactory<CamelliaEncryption, CamelliaDecryption>(16), valdata, 15) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<CamelliaEncryption, CamelliaDecryption>(24), valdata, 15) && pass;	pass = BlockTransformationTest(FixedRoundsCipherFactory<CamelliaEncryption, CamelliaDecryption>(32), valdata, 15) && pass;	return pass;}bool ValidateSalsa(){	cout << "\nSalsa validation suite running...\n";	return RunTestDataFile("TestVectors/salsa.txt");}bool ValidateSosemanuk(){	cout << "\nSosemanuk validation suite running...\n";	return RunTestDataFile("TestVectors/sosemanuk.txt");}bool ValidateVMAC(){	cout << "\nVMAC validation suite running...\n";	return RunTestDataFile("TestVectors/vmac.txt");}bool ValidateCCM(){	cout << "\nAES/CCM validation suite running...\n";	return RunTestDataFile("TestVectors/ccm.txt");}bool ValidateGCM(){	cout << "\nAES/GCM validation suite running...\n";	cout << "\n2K tables:";	bool pass = RunTestDataFile("TestVectors/gcm.txt", MakeParameters(Name::TableSize(), (int)2048));	cout << "\n64K tables:";	return RunTestDataFile("TestVectors/gcm.txt", MakeParameters(Name::TableSize(), (int)64*1024)) && pass;}bool ValidateCMAC(){	cout << "\nCMAC validation suite running...\n";	return RunTestDataFile("TestVectors/cmac.txt");}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -