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

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

?? rsa.cpp

?? RSA算法
?? CPP
字號:
// bmrsa.cpp : Defines the entry point for the console application.
//


#include <string.h>
#include <stdio.h>
#include <time.h>
#include "bignum.h"
#define MAXPRIMECOUNT 1000 // 尋找素數的最大次數
unsigned int nSmallPrimes[MAXPRIMECOUNT][2]; // 小素數數組
unsigned int nPrimeCount = 0; // 尋找素數的次數

// 尋找小素數
void MakeSmallPrimes()
{
   unsigned int n;
   unsigned int j;
   nPrimeCount = 3;
   // 首先定義幾個小素數
   nSmallPrimes[0][0] = 2;
   nSmallPrimes[1][0] = 3;
   nSmallPrimes[2][0] = 5;
   nSmallPrimes[0][1] = 4;
   nSmallPrimes[1][1] = 9;
   nSmallPrimes[2][1] = 25;
   // 開始尋找素數
   for (n=7; nPrimeCount < MAXPRIMECOUNT; n+=2)
   {
      for (j=0; nSmallPrimes[j][1] < n; j++)
      {
         if (j>= nPrimeCount) // 如果大于當前素數組標號,則返回
         {
            return;
         }
         if (n % nSmallPrimes[j][0]==0)  // 如果不是素數,則退出循環
         {
            break;
         }
      }
	  // 找到素數,設置素數
      if (nSmallPrimes[j][1] > n)
      {
         nSmallPrimes[nPrimeCount][0] = n;
         nSmallPrimes[nPrimeCount++][1] = n*n;
      }
   }
}

// 生成隨機大數
CBigNum GenerateBigRandomNumber(unsigned short nBytes)
{
   CBigNum Result=0U; // 初始化大數
   int i;
   clock_t ctStart;
   unsigned long ctr=0;
   
   // 設置時間間隔
   clock_t ctInterval = CLOCKS_PER_SEC / 50 + 1; 

   for (i=0; i<nBytes*2; i++)
   {
      ctStart = clock();
	  // 等到大于時間間隔再開始
      while (clock() - ctStart < ctInterval)
         ctr++;

      ctr = (ctr % 33) & 0xF;

      Result <<= 4U; // 大數左移4位
      Result |= ctr; // 做或運算
   }
   putchar('\n');
   return Result; // 返回大數
}

CBigNum FindABigPrime(unsigned short nBytes)
{
	CBigNum nBig, nBig2;
	DWORD j;
	DWORD nTestCount = 0;
	DWORD nLehmanCount = 0; 
	clock_t ctStartTime = clock(); // 記錄開始時間
	DWORD nOffset=0;
	bool bPrime=false; // 素數標志位
	
	// 開始尋找對應位數的大素數
	for (nBig = GenerateBigRandomNumber(nBytes) | 1U; !bPrime; nBig+=2U, nOffset+=2)
	{
		nTestCount++;
		for (j=0; j<nPrimeCount; j++)
		{
			// 如果不是大素數,則退出循環
			if (nBig % nSmallPrimes[j][0] == 0)
			{
				break;
			}
		}
		
		if (j<nPrimeCount)
			continue;
		nLehmanCount++;
		nBig2 = (nBig - 1U) / 2U;
		// 設置一些隨機的素數
		DWORD arnLehmanPrimes[] = { 89, 5179, 25981, 25439, 25013, 25667, 27397 };
		// 初始化大數組
		CBigNum LehmanResults[sizeof(arnLehmanPrimes) / sizeof(arnLehmanPrimes[0])];
		nBig2 = nBig - 1U;
		bPrime = true;
		for (j=0; j<sizeof(arnLehmanPrimes) / sizeof(arnLehmanPrimes[0]); j++)
		{
			// 開始生成大素數
			LehmanResults[j] = 
				CBigNum(arnLehmanPrimes[j]).PowMod(nBig2, nBig, CLOCKS_PER_SEC);
			if (LehmanResults[j] == nBig2)
			{
			}
			else if (LehmanResults[j] == 1U)
			{
			}
			else // 不是大素數
			{	
				bPrime = false;
				break;
			}
		}
		// 找到大素數
		if (bPrime) 
		{
			break;
		}
	}	
	return nBig; // 返回大素數
}

// 生成公鑰和私鑰
void GenKeyPair(CBigNum &PublicMod, CBigNum &PublicKey, CBigNum &PrivateKey, CBigNum &P, CBigNum &Q, unsigned int nByteCount = 32)
{
   if (0U==(P | Q))
   {
      P=FindABigPrime(nByteCount); // 生成nByteCount位的大素數
      Q=FindABigPrime(nByteCount); // 生成nByteCount位的大素數
      PublicKey=GenerateBigRandomNumber(nByteCount) | 1U;
   } else {
      PublicKey |= 1U;
   }
   PrivateKey = (P-1U) * (Q-1U); // 初始化私鑰
   while (PublicKey > PrivateKey)
      PublicKey=GenerateBigRandomNumber(nByteCount-1) | 1U;
   while(CBigNum::gcd(PublicKey,PrivateKey) != 1U) // 生成公鑰
      PublicKey+=2; // 累加直至互素
   PrivateKey = PublicKey.Inverse(PrivateKey); // 生成私鑰

   PublicMod = P*Q; // 公鑰n的生成
}





// 生成特定格式的公鑰和私鑰
void GenerateKeys(CBigNumString &PublicMod, CBigNumString &PublicKey, CBigNumString &PrivateKey, unsigned short nBytes)
{
	CBigNum PubMod, PubKey, PriKey, PriP, PriQ;
	MakeSmallPrimes();
    GenKeyPair(PubMod, PubKey, PriKey, PriP, PriQ, nBytes); // 生成公鑰和私鑰
	// 將公鑰和私鑰轉換成16進制形式
	PublicMod = PubMod.ToHexString(); 
	PublicKey = PubKey.ToHexString();
	PrivateKey = PriKey.ToHexString();
}

CBigNumString strMod, strPubKey, strPriKey; // 初始化大數字符變量

// RSA加密函數
void RSAEncrypt(char *publickey,char *publicmod, char *output, unsigned int *outputlen, char *input, unsigned int inputlen)
{
	CBigNum Transform;
	CBigNum PubMod, PubKey;
	CBigNumString strTransform;
	// 將公鑰轉換成大數
	PubMod = CBigNum::FromHexString(publicmod);
	PubKey = CBigNum::FromHexString(publickey); 
    
	// 轉換輸入的明文
	Transform = Transform.FromByteString(input);
	// 使用RSA加密明文
	Transform = Transform.PowMod(PubKey,PubMod);
	// 將密文轉換成16進制的字符
	strTransform = Transform.ToHexString();
	
	// 輸出密文長度
	*outputlen = strlen((const char*)strTransform)+1;
	// 輸出密文
	memcpy(output,(const char*)strTransform,(*outputlen)+1);
}

// RSA解密
void RSADecrypt(char *output, unsigned int *outputlen, char *input, unsigned int inputlen)
{
	CBigNum Transform;
	CBigNum PubMod,PriKey;
	CBigNumString strTransform;
	// 將私鑰轉換成大數
	PubMod = CBigNum::FromHexString((const char*)strMod);
	PriKey = CBigNum::FromHexString((const char*)strPriKey);
    // 轉換輸入的密文
	Transform = Transform.FromHexString(input);
	// 使用RSA對密文進行解密
	Transform = Transform.PowMod(PriKey,PubMod);
    // 將解密文轉換成字節字符串
	strTransform = Transform.ToByteString();
    
	// 輸出解密文長度
	*outputlen = strlen((const char*)strTransform)+1;
	// 輸出解密文
	memcpy(output,(const char*)strTransform,(*outputlen)+1);


}



int main(int argc, char* argv[])
{
	
	char pubkey[300]; // 公鑰
	char pubmod[300]; // 公鑰
	char encrypt_text[300]; // 輸出的密文
	char decrypt_text[300]; // 輸出的解密文
	unsigned int pubkeylen;
	unsigned int encrypt_len;
	unsigned int decrypt_len;
	char plain_text[50];
	strcpy(plain_text,"Welcome to RSA world!");	
	// 產生公鑰和私鑰
	GenerateKeys(strMod,strPubKey,strPriKey,64);
	// 設置公鑰字符串
	// 這里轉換成char型的是為了在網絡上傳輸方便
	memcpy(pubkey,(const char*)strPubKey,strlen((const char*)strPubKey)+1);
	memcpy(pubmod,(const char*)strMod,strlen((const char*)strMod)+1);
	
    // 使用RSA進行加密
	RSAEncrypt(pubkey,pubmod,encrypt_text,&encrypt_len,plain_text,sizeof(plain_text));
    // 使用RSA進行解密
	RSADecrypt(decrypt_text,&decrypt_len,encrypt_text,encrypt_len);
	printf("公鑰n :  %s\n",pubmod);
	printf("公鑰e :  %s\n",pubkey);
	printf("\n現在可以把公鑰傳輸給明文所有者進行加密\n\n");
    printf("加密前的明文:\n");
	printf("%s\n\n\n",plain_text);
	printf("加密后的密文:\n");
	printf("%s\n\n\n",encrypt_text);
	printf("解密后的輸出:\n");
	printf("%s\n\n\n",decrypt_text);
	getchar();
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美国产综合| 亚洲精品视频自拍| 国内精品国产三级国产a久久| 欧美精品一卡二卡| 国产精品91xxx| 一区二区久久久久| 日韩亚洲欧美在线| 成年人网站91| 日本欧美加勒比视频| 欧美国产一区在线| 欧美一区午夜视频在线观看| 国产99久久久精品| 日本亚洲三级在线| 亚洲黄色在线视频| 久久一夜天堂av一区二区三区| 一本一本大道香蕉久在线精品 | 懂色av中文字幕一区二区三区| 亚洲精品高清视频在线观看| 久久久久99精品一区| 欧美成人精品3d动漫h| 日本高清无吗v一区| 91.成人天堂一区| 日本伦理一区二区| 99精品久久99久久久久| 国产.欧美.日韩| 国产+成+人+亚洲欧洲自线| 欧美aaaaaa午夜精品| 日本中文字幕一区二区有限公司| 亚洲成人免费观看| 国产精品一区二区三区网站| 成人一区二区视频| 亚洲一区二区三区美女| 国产精品1区2区3区| 99久久婷婷国产综合精品 | 亚洲va天堂va国产va久| 1区2区3区精品视频| 欧美国产日产图区| 精品国产凹凸成av人网站| 91精品国产丝袜白色高跟鞋| 91国产视频在线观看| 成人久久久精品乱码一区二区三区| 美女视频黄久久| 成人黄色a**站在线观看| 欧美一级片免费看| 亚洲欧美另类小说| 国产成人亚洲精品青草天美| 欧美视频在线一区二区三区| 日韩一区和二区| 国产精品久久久久影院| 亚洲国产精品尤物yw在线观看| 加勒比av一区二区| 色婷婷综合久久| 欧美电影免费观看高清完整版在| 日韩理论片在线| 国产99一区视频免费| 欧美一区二区三区婷婷月色| 中文字幕一区二区三区不卡 | 欧美视频在线一区| 无码av中文一区二区三区桃花岛| caoporn国产一区二区| 制服丝袜亚洲精品中文字幕| 亚洲国产成人av| 91香蕉视频污在线| 亚洲欧美视频在线观看视频| 国产很黄免费观看久久| 久久久国产一区二区三区四区小说| 伊人色综合久久天天人手人婷| 北条麻妃一区二区三区| 国产精品视频你懂的| 懂色av一区二区三区免费观看| 精品日韩欧美在线| 国产成人免费视频网站| 日韩欧美在线不卡| 日本免费新一区视频| 精品av久久707| 美女性感视频久久| 久久综合色一综合色88| 国产一区 二区| 久久久精品影视| 国产麻豆精品在线观看| 国产精品久久三区| 91麻豆国产精品久久| 亚洲777理论| 日韩一区二区免费视频| 奇米色777欧美一区二区| 久久综合成人精品亚洲另类欧美| 国产一区二区免费看| 午夜精品久久久久久久久| 久久色在线观看| 欧美日韩中文字幕一区二区| 99国产一区二区三精品乱码| 成人av免费在线观看| 国产91精品入口| 成人网在线免费视频| 日韩美女啊v在线免费观看| 欧美日韩视频在线一区二区| 国产成人小视频| 久久国产精品色| 亚洲123区在线观看| 亚洲视频在线一区观看| 久久综合九色综合97婷婷| 91精品国产综合久久香蕉麻豆| av午夜一区麻豆| 国产电影精品久久禁18| 日韩精品1区2区3区| 亚洲国产精品久久艾草纯爱| 中文字幕在线观看不卡视频| 久久久久国产成人精品亚洲午夜| 7777女厕盗摄久久久| 欧美午夜寂寞影院| 色狠狠综合天天综合综合| gogo大胆日本视频一区| 99视频精品在线| 成人91在线观看| 色婷婷综合久久久中文一区二区| 91尤物视频在线观看| 欧美亚洲一区二区在线| 欧美日韩一级二级三级| 欧美一级高清大全免费观看| 久久婷婷一区二区三区| 亚洲欧美日韩在线| 奇米四色…亚洲| 91欧美一区二区| 欧美日韩亚洲综合一区| 亚洲精品一区二区三区99| 日本一区二区三区久久久久久久久不| 国产欧美一区二区在线| 亚洲男人的天堂网| 亚洲123区在线观看| 国产成人av资源| 3d成人h动漫网站入口| 久久亚洲精华国产精华液 | 在线观看亚洲专区| 久久久亚洲精品石原莉奈| 国产精品嫩草影院com| 午夜精品影院在线观看| 成人午夜短视频| 日韩欧美亚洲国产精品字幕久久久| 国产精品免费丝袜| 麻豆精品视频在线观看免费| 91麻豆精品一区二区三区| 精品国产制服丝袜高跟| 亚洲v中文字幕| 欧美日韩一区二区在线观看视频| 国产精品私房写真福利视频| 另类的小说在线视频另类成人小视频在线 | 首页亚洲欧美制服丝腿| 99久久精品免费| 欧美激情一区二区三区| 高清视频一区二区| 欧美激情在线免费观看| 成人99免费视频| 亚洲欧洲日韩在线| 99国产精品视频免费观看| 亚洲精品欧美激情| 国产成人欧美日韩在线电影| 国产午夜精品一区二区三区四区| 另类欧美日韩国产在线| 日韩免费高清电影| 激情图片小说一区| 国产亚洲成年网址在线观看| 国产**成人网毛片九色 | 日韩精品一二三区| 精品久久久久久最新网址| 国产综合色精品一区二区三区| 精品久久久三级丝袜| 成人动漫在线一区| 久久99国产精品麻豆| 国产亚洲精品精华液| 91一区二区三区在线观看| 日韩专区欧美专区| 国产精品久久久久久久蜜臀| 欧美色图天堂网| 国产精品123| 日本不卡视频在线| 亚洲一区二区三区四区在线观看 | 香蕉成人啪国产精品视频综合网 | 成人激情av网| 国产河南妇女毛片精品久久久| 亚洲一区国产视频| 国产区在线观看成人精品| 日韩午夜电影在线观看| 一本到高清视频免费精品| 色婷婷亚洲综合| 成人听书哪个软件好| 美女网站在线免费欧美精品| 亚洲视频一二区| 久久精品人人做人人爽97| 欧美精品久久久久久久多人混战| 粉嫩高潮美女一区二区三区| 美腿丝袜亚洲色图| 激情都市一区二区| 狠狠色综合色综合网络| 婷婷综合另类小说色区| 亚洲成人在线网站| 亚洲国产精品久久不卡毛片| 亚洲成人动漫在线免费观看| 亚洲一区电影777| 日韩av一级电影| 国产真实乱对白精彩久久|