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

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

?? rijndaeltest-ref.c

?? AES(The Advanced Encryption Standard)是美國國家標準與技術研究所用于加密電子數據的規范
?? C
?? 第 1 頁 / 共 2 頁
字號:
		exit (EXIT_FAILURE);			}	if (NULL != (fp2 = fopen("table.256","r"))) {		rijndaelTKAT (fp, 128, 256,fp2);		fclose(fp2);	} else {		printf("Table Known Answer test expects file table.192\n");		fclose(fp);		exit (EXIT_FAILURE);			}		fprintf (fp,		"\n"		"==========");	fclose (fp);	/* prepare Intermediate Values Known Answer Tests: */	fp = fopen (ivFile, "w");	fprintf (fp,		"\n"		"=========================\n"		"\n"		"FILENAME:  \"%s\"\n"		"\n"		"Electronic Codebook (ECB) Mode\n"		"Intermediate Value Known Answer Tests\n"		"\n"		"Algorithm Name: Rijndael\n"		"Principal Submitter: %s\n",		ivFile,SUBMITTER);	fflush (fp);	rijndaelIVKAT (fp, 128, BITSPERBLOCK);	rijndaelIVKAT (fp, 192, BITSPERBLOCK);	rijndaelIVKAT (fp, 256, BITSPERBLOCK);	fprintf (fp,		"\n"		"==========");	fclose (fp);}static void rijndaelECB_MCT (FILE *fp, const char *initKey, int keyLength,	const char *initBlock, int blockLength, BYTE direction){	int i, j;	BYTE inBlock[4*MAXBC], outBlock[4*MAXBC], binKey[4*MAXKC];	BYTE keyMaterial[320];	keyInstance keyInst;	cipherInstance cipherInst;#ifdef TRACE_KAT_MCT	int width = 0;	clock_t elapsed = -clock();	printf ("Executing ECB MCT (%s, key %d): ",		direction == DIR_ENCRYPT ? "ENCRYPT" : "DECRYPT", keyLength);	fflush (stdout);#endif /* ?TRACE_KAT_MCT */	fprintf (fp,		"\n"		"=========================\n"		"\n"		"KEYSIZE=%d\n", keyLength);	fflush (fp);	HexToBin (outBlock, initBlock, blockLength);	HexToBin (binKey, initKey, keyLength);	for (i = 0; i < 400; i++) {#ifdef TRACE_KAT_MCT                         while (width-- > 0) putchar ('\b'); width = printf ("%d", i); fflush (stdout);    #endif /* ?TRACE_KAT_MCT */		fprintf (fp, "\nI=%d\n", i);		/* prepare key: */		for (j = 0; j < keyLength/8; j++) {			sprintf (&keyMaterial[2*j], "%02X", binKey[j]);		}		keyMaterial[keyLength/4] = 0;		fprintf (fp, "KEY=%s\n", keyMaterial);		keyInst.blockLen = blockLength;		makeKey(&keyInst, direction, keyLength, keyMaterial);		/* do encryption/decryption: */		blockPrint (fp, outBlock, blockLength, direction == DIR_ENCRYPT ? "PT" : "CT");		cipherInst.blockLen = blockLength;		cipherInit (&cipherInst, MODE_ECB, NULL);		if (direction == DIR_ENCRYPT) {			for (j = 0; j < 10000; j++) {				memcpy (inBlock, outBlock, blockLength/8);				blockEncrypt(&cipherInst, &keyInst, inBlock, blockLength, outBlock);			}		} else {			for (j = 0; j < 10000; j++) {				memcpy (inBlock, outBlock, blockLength/8);				blockDecrypt(&cipherInst, &keyInst, inBlock, blockLength, outBlock);			}		}		blockPrint (fp, outBlock, blockLength, direction == DIR_ENCRYPT ? "CT" : "PT");		/* prepare new key: */		switch (keyLength) {		case 128:			for (j = 0; j < 128/8; j++) {				binKey[j] ^= outBlock[j];			}			break;		case 192:			for (j = 0; j < 64/8; j++) {				binKey[j] ^= inBlock[j + 64/8];			}			for (j = 0; j < 128/8; j++) {				binKey[j + 64/8] ^= outBlock[j];			}			break;		case 256:			for (j = 0; j < 128/8; j++) {				binKey[j] ^= inBlock[j];			}			for (j = 0; j < 128/8; j++) {				binKey[j + 128/8] ^= outBlock[j];			}			break;		}	}#ifdef TRACE_KAT_MCT	elapsed += clock();	printf (" done (%.1f s).\n", (float)elapsed/CLOCKS_PER_SEC);#endif /* ?TRACE_KAT_MCT */} /* rijndaelECB_MCT */static void rijndaelCBC_MCT (FILE *fp, const char *initKey, int keyLength,	const char *initIV, const char *initBlock, int blockLength, BYTE direction){	int i, j, r, t;	BYTE inBlock[256/8], outBlock[256/8], binKey[256/8], cv[256/8];	BYTE keyMaterial[320];	BYTE iv[64+1];	keyInstance keyInst;	cipherInstance cipherInst;#ifdef TRACE_KAT_MCT	int width = 0;	clock_t elapsed = -clock();	printf ("Executing CBC MCT (%s, key %d): ",		direction == DIR_ENCRYPT ? "ENCRYPT" : "DECRYPT", keyLength);	fflush (stdout);#endif /* ?TRACE_KAT_MCT */	fprintf (fp,		"\n"		"==========\n"		"\n"		"KEYSIZE=%d\n", keyLength);	fflush (fp);	HexToBin (inBlock, initBlock, blockLength); /* this is either PT0 or CT0 */	HexToBin (cv, initIV, blockLength);	HexToBin (binKey, initKey, keyLength);	for (i = 0; i < 400; i++) {#ifdef TRACE_KAT_MCT                         while (width-- > 0) putchar ('\b'); width = printf ("%d", i); fflush (stdout);    #endif /* ?TRACE_KAT_MCT */		fprintf (fp, "\nI=%d\n", i);		/* prepare key: */		for (j = 0; j < keyLength/8; j++) {			sprintf (&keyMaterial[2*j], "%02X", binKey[j]);		}		keyMaterial[keyLength/4] = 0;		fprintf (fp, "KEY=%s\n", keyMaterial);		keyInst.blockLen = blockLength;		r = makeKey(&keyInst, direction, keyLength, keyMaterial);		if (TRUE != r) {			fprintf(stderr,"makeKey error %d\n",r);			exit(-1);		}		/* do encryption/decryption: */		blockPrint (fp, cv, blockLength, "IV");		blockPrint (fp, inBlock, blockLength, direction == DIR_ENCRYPT ? "PT" : "CT");		if (direction == DIR_ENCRYPT) {			for (j = 0; j < 10000; j++) {				for(t = 0; t < blockLength/8; t++) {					sprintf(iv+2*t,"%02x",cv[t]);									}				cipherInst.blockLen = blockLength;				r = cipherInit (&cipherInst, MODE_CBC, iv);				if (TRUE != r) {					fprintf(stderr,"cipherInit error %d\n",r);					exit(-1);				}				r = blockEncrypt(&cipherInst, &keyInst, inBlock, blockLength, outBlock);				if (blockLength != r) {					fprintf(stderr,"blockEncrypt error %d\n",r);					exit(-1);				}				memcpy (inBlock, cv, blockLength/8);				memcpy (cv, outBlock, blockLength/8);			}		} else {			for (j = 0; j < 10000; j++) {				for(t = 0; t < blockLength/8; t++) {					sprintf(iv+2*t,"%02x",cv[t]);									}				cipherInst.blockLen = blockLength;				cipherInit (&cipherInst, MODE_CBC, iv);				blockDecrypt(&cipherInst, &keyInst, inBlock, blockLength, outBlock);				memcpy (cv, inBlock, blockLength/8);				memcpy (inBlock, outBlock, blockLength/8);			}		}		blockPrint (fp, outBlock, blockLength, direction == DIR_ENCRYPT ? "CT" : "PT");		/* prepare new key: */		switch (keyLength) {		case 128:			for (j = 0; j < 128/8; j++) {				binKey[j] ^= outBlock[j];			}			break;		case 192:			for (j = 0; j < 64/8; j++) {				if (direction == DIR_ENCRYPT)					binKey[j] ^= inBlock[j + 64/8];				else					binKey[j] ^= cv[j + 64/8];			}			for (j = 0; j < 128/8; j++) {				binKey[j + 64/8] ^= outBlock[j];			}			break;		case 256:			for (j = 0; j < 128/8; j++) {				if (direction == DIR_ENCRYPT)					binKey[j] ^= inBlock[j];				else					binKey[j] ^= cv[j];			}			for (j = 0; j < 128/8; j++) {				binKey[j + 128/8] ^= outBlock[j];			}			break;		}	}#ifdef TRACE_KAT_MCT	elapsed += clock();	printf (" done (%.1f s).\n", (float)elapsed/CLOCKS_PER_SEC);#endif /* ?TRACE_KAT_MCT */} /* rijndaelCBC_MCT */static void makeMCTs (const char *ecbEncryptionFile, const char *ecbDecryptionFile,	const char *cbcEncryptionFile, const char *cbcDecryptionFile){	FILE *fp;	/* prepare ECB Encryption Monte Carlo Tests: */	fp = fopen (ecbEncryptionFile, "w");	fprintf (fp,		"\n"		"=========================\n"		"\n"		"FILENAME:  \"%s\"\n"		"\n"		"Electronic Codebook (ECB) Mode - ENCRYPTION\n"		"Monte Carlo Test\n"		"\n"		"Algorithm Name: Rijndael\n"		"Principal Submitter: %s\n",		ecbEncryptionFile,SUBMITTER);	fflush (fp);	rijndaelECB_MCT (fp,		"00000000000000000000000000000000", 128,		"00000000000000000000000000000000", BITSPERBLOCK, DIR_ENCRYPT);	rijndaelECB_MCT (fp,		"000000000000000000000000000000000000000000000000", 192,		"00000000000000000000000000000000", BITSPERBLOCK, DIR_ENCRYPT);	rijndaelECB_MCT (fp,		"0000000000000000000000000000000000000000000000000000000000000000", 256,		"00000000000000000000000000000000", BITSPERBLOCK, DIR_ENCRYPT);	fprintf (fp,		"\n"		"===========");	fclose (fp);	/* prepare ECB Decryption Monte Carlo Tests: */	fp = fopen (ecbDecryptionFile, "w");	fprintf (fp,		"\n"		"=========================\n"		"\n"		"FILENAME:  \"%s\"\n"		"\n"		"Electronic Codebook (ECB) Mode - DECRYPTION\n"		"Monte Carlo Test\n"		"\n"		"Algorithm Name: Rijndael\n"		"Principal Submitter: %s\n",		ecbDecryptionFile,SUBMITTER);	fflush (fp);	rijndaelECB_MCT (fp,		"00000000000000000000000000000000", 128,		"00000000000000000000000000000000", BITSPERBLOCK, DIR_DECRYPT);	rijndaelECB_MCT (fp,		"000000000000000000000000000000000000000000000000", 192,		"00000000000000000000000000000000", BITSPERBLOCK, DIR_DECRYPT);	rijndaelECB_MCT (fp,		"0000000000000000000000000000000000000000000000000000000000000000", 256,		"00000000000000000000000000000000", BITSPERBLOCK, DIR_DECRYPT);	fprintf (fp,		"\n"		"===========");	fclose (fp);	/* prepare CBC Encryption Monte Carlo Tests: */	fp = fopen (cbcEncryptionFile, "w");	fprintf (fp,		"\n"		"=========================\n"		"\n"		"FILENAME:  \"%s\"\n"		"\n"		"Cipher Block Chaining (CBC) Mode - ENCRYPTION\n"		"Monte Carlo Test\n"		"\n"		"Algorithm Name: Rijndael\n"		"Principal Submitter: %s\n",		cbcEncryptionFile,SUBMITTER);	fflush (fp);	rijndaelCBC_MCT (fp,		"00000000000000000000000000000000", 128,		"00000000000000000000000000000000", "00000000000000000000000000000000", BITSPERBLOCK,		DIR_ENCRYPT);	rijndaelCBC_MCT (fp,		"000000000000000000000000000000000000000000000000", 192,		"00000000000000000000000000000000", "00000000000000000000000000000000", BITSPERBLOCK,		DIR_ENCRYPT);	rijndaelCBC_MCT (fp,		"0000000000000000000000000000000000000000000000000000000000000000", 256,		"00000000000000000000000000000000", "00000000000000000000000000000000", BITSPERBLOCK,		DIR_ENCRYPT);	fprintf (fp,		"\n"		"===========");	fclose (fp); 	/* prepare CBC Decryption Monte Carlo Tests: */	fp = fopen (cbcDecryptionFile, "w");	fprintf (fp,		"\n"		"=========================\n"		"\n"		"FILENAME:  \"%s\"\n"		"\n"		"Cipher Block Chaining (CBC) Mode - DECRYPTION\n"		"Monte Carlo Test\n"		"\n"		"Algorithm Name: Rijndael\n"		"Principal Submitter: %s\n",		cbcDecryptionFile,SUBMITTER);	fflush (fp);	rijndaelCBC_MCT (fp,		"00000000000000000000000000000000", 128,		"00000000000000000000000000000000", "00000000000000000000000000000000", BITSPERBLOCK,		DIR_DECRYPT);	rijndaelCBC_MCT (fp,		"000000000000000000000000000000000000000000000000", 192,		"00000000000000000000000000000000", "00000000000000000000000000000000", BITSPERBLOCK,		DIR_DECRYPT);	rijndaelCBC_MCT (fp,		"0000000000000000000000000000000000000000000000000000000000000000", 256,		"00000000000000000000000000000000", "00000000000000000000000000000000", BITSPERBLOCK,		DIR_DECRYPT);	fprintf (fp,		"\n"		"===========");	fclose (fp);	} /* makeMCTs */int main (void){	makeKATs ("ecb_vk.txt", "ecb_vt.txt", "ecb_tbl.txt", "ecb_iv.txt");	makeMCTs ("ecb_e_m.txt", "ecb_d_m.txt", "cbc_e_m.txt", "cbc_d_m.txt");		return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产3级a| 天天色天天操综合| 亚洲成人在线观看视频| 久久精品99国产精品| 91麻豆国产在线观看| www国产精品av| 午夜视频在线观看一区二区| 成人一级视频在线观看| 日韩欧美一区二区三区在线| 亚洲一区中文在线| 99这里只有精品| 久久久亚洲午夜电影| 另类中文字幕网| 欧美日韩国产另类一区| 亚洲激情av在线| 成人av电影免费在线播放| 久久综合久久综合久久| 免费在线观看日韩欧美| 欧美精品久久99久久在免费线| 成人免费在线视频| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 91麻豆精品91久久久久同性| 亚洲视频在线观看三级| 波多野结衣中文字幕一区二区三区| 中文字幕在线观看不卡视频| 国产激情91久久精品导航 | 日本欧洲一区二区| 欧美在线观看你懂的| 亚洲激情男女视频| 在线观看av一区| 亚洲午夜精品在线| 欧美精品三级日韩久久| 亚洲精品国产一区二区三区四区在线| www.色综合.com| 亚洲欧洲综合另类| 色激情天天射综合网| 一区二区三区精品在线观看| 欧美在线观看视频一区二区 | 精品制服美女久久| 亚洲素人一区二区| av一区二区三区| 亚洲激情图片一区| 欧美群妇大交群的观看方式| 日韩成人精品在线观看| 日韩欧美久久一区| 国产伦精品一区二区三区免费迷| 国产欧美综合在线观看第十页 | 欧美在线高清视频| 天堂午夜影视日韩欧美一区二区| 欧美一区二区三区日韩| 韩国欧美一区二区| 亚洲欧洲日韩在线| 欧美三区在线观看| 精品一区免费av| 国产精品久久久久久亚洲毛片 | 亚洲一二三四区不卡| 3atv在线一区二区三区| 国产二区国产一区在线观看| 日韩伦理av电影| 91精品在线免费观看| 国产一区二区免费看| 亚洲美女在线国产| 日韩欧美一区电影| 色综合久久久网| 蜜臀av亚洲一区中文字幕| 欧美国产一区视频在线观看| 在线观看国产精品网站| 国产一区二区美女| 一区二区三区中文字幕电影 | 中文字幕亚洲精品在线观看| 欧美日韩免费电影| 国产白丝精品91爽爽久久 | 精品在线播放午夜| 亚洲美女一区二区三区| 26uuu另类欧美| 欧美三级视频在线播放| 国产精品一区专区| 婷婷久久综合九色综合绿巨人 | av午夜精品一区二区三区| 五月天激情综合网| 自拍视频在线观看一区二区| 日韩精品中文字幕一区二区三区| 99vv1com这只有精品| 激情综合网最新| 亚洲大片精品永久免费| 国产精品福利一区二区三区| 欧美一级免费观看| 色狠狠色噜噜噜综合网| 国产精品一线二线三线精华| 婷婷开心久久网| 玖玖九九国产精品| 一区二区三区在线观看欧美| 国产精品网站在线| 欧美变态tickle挠乳网站| 欧美视频一区二区在线观看| 99久久精品免费| 成人深夜视频在线观看| 国产九色sp调教91| 麻豆成人久久精品二区三区红| 亚洲国产sm捆绑调教视频| 18欧美乱大交hd1984| 国产精品免费看片| 国产午夜精品在线观看| 久久综合九色综合欧美亚洲| 欧美一区二区三区啪啪| 欧美日韩国产综合一区二区| 色偷偷成人一区二区三区91 | 久热成人在线视频| 日韩 欧美一区二区三区| 亚洲国产精品人人做人人爽| 又紧又大又爽精品一区二区| 亚洲人成亚洲人成在线观看图片| 国产精品情趣视频| 国产精品热久久久久夜色精品三区 | 美国精品在线观看| 青青草91视频| 久久精品国产亚洲高清剧情介绍| 青娱乐精品在线视频| 日本欧美一区二区在线观看| 秋霞影院一区二区| 久久aⅴ国产欧美74aaa| 精品一区二区三区影院在线午夜| 美女视频一区二区三区| 激情久久五月天| 国产成人午夜高潮毛片| 成人免费毛片高清视频| 99久久婷婷国产综合精品电影 | 成人性生交大合| 波多野结衣视频一区| 色综合激情五月| 欧美日韩视频第一区| 91精品国产欧美日韩| 精品福利一二区| 国产精品视频免费看| 成人免费在线观看入口| 亚洲午夜电影在线观看| 久久国产视频网| 粉嫩绯色av一区二区在线观看| 91在线小视频| 欧美高清视频不卡网| 久久免费的精品国产v∧| 国产精品美女视频| 午夜精品在线看| 国产又粗又猛又爽又黄91精品| 欧美一区二区视频在线观看2022| 欧美mv和日韩mv国产网站| 欧美激情一区二区三区| 亚洲国产色一区| 国产麻豆成人精品| 一本一道综合狠狠老| 日韩女同互慰一区二区| 国产精品久久久久婷婷| 五月天视频一区| 成人激情免费网站| 91精品国产日韩91久久久久久| 国产精品女主播av| 日本成人在线一区| 99久久综合国产精品| 欧美一区二区私人影院日本| 国产精品福利一区| 蜜桃视频在线观看一区二区| 97久久精品人人澡人人爽| 91精品国产欧美日韩| 成人欧美一区二区三区在线播放| 日本美女一区二区| 日本电影亚洲天堂一区| 久久久99精品久久| 丝袜诱惑亚洲看片| 91免费国产在线| 国产欧美精品一区二区色综合| 男人的j进女人的j一区| 在线视频综合导航| 欧美国产欧美亚州国产日韩mv天天看完整| 亚洲午夜日本在线观看| 91一区二区在线| 欧美经典一区二区三区| 久久国产精品第一页| 69久久99精品久久久久婷婷| 亚洲精品日韩一| 99re这里只有精品视频首页| 久久久久久久久久久久电影| 蜜芽一区二区三区| 欧美嫩在线观看| 亚洲国产色一区| 91精品91久久久中77777| 一色桃子久久精品亚洲| 国产91在线观看丝袜| 26uuu久久综合| 紧缚奴在线一区二区三区| 日韩一区二区免费视频| 秋霞电影网一区二区| 欧美日韩成人综合| 亚洲国产成人av| 欧美性色综合网| 亚洲自拍另类综合| 欧美亚洲国产bt| 亚洲电影在线播放| 欧美日韩视频在线观看一区二区三区| 夜夜嗨av一区二区三区| 欧美在线观看一二区|