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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rsa.h

?? rsa加密算法的vc實(shí)現(xiàn)
?? H
字號(hào):
#ifndef RSA_H
#define RSA_H

#include<fstream>
#include<cstdio>
using namespace std;
#include"BigInt.h"
class rsa{
public:
	rsa();
	~rsa();
	void setkey(const BigInt& prp, const BigInt& prq, const BigInt& pubk);
	void setpubkey(const BigInt& pubk, const BigInt& n);
	void setMFileName(char* rsa_m);
	void setCFileName(char* rsa_c);
	void DeCode(int choose, int base);
	void EnCode(int choose, int base);
private:
	void init();
	void DeCodingProcess(int choose, int base);
	void DeCodingSpecial(int choose, int base);
	void EnCodingProcess(int base);
	void EnCodingSpecial(int base);
	BigInt primeP;
	BigInt primeQ;
	BigInt modn;
	BigInt pubkey;
	BigInt prikey;
	BigInt fp;
	BigInt fq;
	char* rsach;
	char rsacFile[30];
	char rsamFile[30];
	int rsal;
};

rsa::rsa()
{
	primeP = 952559;
	primeQ = 999983;
	pubkey = 11;
	init();
	rsach = NULL;
	strcpy(rsacFile, "c.txt");
	strcpy(rsamFile, "m.txt");
}
rsa::~rsa()
{
	primeP.clear();
	primeQ.clear();
	modn.clear();
	pubkey.clear();
	prikey.clear();
	fp.clear();
	fq.clear();
}

void rsa::init()
{
	modn = primeP * primeQ;
	--primeP;
	--primeQ;
	prikey = primeP * primeQ;
	prikey = pubkey.BIinverse(prikey);
	++primeP;
	++primeQ;
	rsal = modn.nodeNumber();
	rsal *= 32;
	intNode* t = modn.getHead();
	if(TheLastNode(t))
		rsal -= FindZeroBit(t->num);
	fp = primeP.BIinverse(primeQ);
	fq = primeQ.BIinverse(primeP);

}
void rsa::setkey(const BigInt& prp, const BigInt& prq, const BigInt& pubk)
{
	primeP.copy(prp);
	primeQ.copy(prq);
	pubkey.copy(pubk);
	init();
}
void rsa::setpubkey(const BigInt& pubk, const BigInt& n)
{
	pubkey.copy(pubk);
	modn.copy(n);
	rsal = modn.nodeNumber();
	rsal *= 32;
	intNode* t = modn.getHead();
	if(TheLastNode(t))
		rsal -= FindZeroBit(t->num);

}
void rsa::setMFileName(char* rsa_m)
{
	strcpy(rsamFile, rsa_m);
}
void rsa::setCFileName(char* rsa_c)
{
	strcpy(rsacFile, rsa_c);
}
//1. represent number based on decimal.
//2. represent number based on hex.
//3. represent with a = 01, b = 02........... to decimal
void rsa::EnCode(int choose,int base)
{
	switch(choose)
	{
	case 1:
		EnCodingProcess(base);
		break;
	case 2:
		EnCodingSpecial(base);
		break;
	default:
		break;
	}
}
void rsa::DeCode(int choose, int base)
{
	switch(choose)
	{
	case 1:
		DeCodingProcess(choose, base);
		break;
	case 2:
		DeCodingProcess(choose, base);
		break;
	case 3:
		DeCodingSpecial(choose, base);
		break;
	case 4:
		DeCodingSpecial(choose, base);
		break;
	default:
		break;
	}
}

void rsa::EnCodingProcess(int base)
{
	FILE* fp;
	if( (fp = fopen(rsamFile, "r") ) == NULL)
		return;

	fstream out;
	out.open(rsacFile, ios::out);

	int r_length;
	r_length = rsal  / 8;
	rsach = new char[r_length];

	BigInt temp;
	char* rsa_re;
	int rsa_leng;
	int count = 0;
	int i;

	int times = 0;
	while(! feof(fp))
	{
		rsach[count++] = fgetc(fp);
		if(count == r_length)
		{
			++times;
			cout << "第 " << times << " 輪加密!";
			count = 0;
			temp.loadSTR(rsach, r_length);
			temp = BImodexp2(temp, pubkey, modn);
			if(base == 10)
				rsa_re = temp.outputDEC(rsa_leng);
			else
				rsa_re = temp.outputHEX(rsa_leng);
			for(i = 0; i < rsa_leng; ++i)
				out << rsa_re[i];
			delete[] rsa_re;
			out << endl;
		}
	}
	++times;
	cout << "第 " << times << " 輪加密!";
	temp.loadSTR(rsach, count);
	temp = BImodexp2(temp, pubkey, modn);
	if(base == 10)
		rsa_re = temp.outputDEC(rsa_leng);
	else
		rsa_re = temp.outputHEX(rsa_leng);
	for(i = 0; i < rsa_leng; ++i)
			out << rsa_re[i];
	delete[] rsa_re;

	delete[] rsach;
	temp.clear();
	out.close();
	fclose(fp);
}

void rsa::DeCodingProcess(int choose, int base)
{
	fstream out;
	fstream in;
	in.open(rsacFile, ios::in);
	out.open(rsamFile, ios::out);

	BigInt temp;
	BigInt temp1;
	BigInt temp2;
	int r_length;
	char* rr;
	r_length = rsal * 3  / 10;
	rsach = new char[r_length + 5];

	int times = 0;
	while(in >> rsach)
	{
		++times;
		cout << "第 " << times << " 輪解密!";
		if(base == 10)
			temp.loadDEC(rsach, strlen(rsach));
		else
			temp.loadHEX(rsach, strlen(rsach));
		if(choose == 1)
			temp = BImodexp2(temp, prikey, modn);
		else
		{
			temp1 = BImodexp2(temp, prikey, primeP);
			temp2 = BImodexp2(temp, prikey, primeQ);
			temp1 = temp1 * fq;
			temp1 = temp1 * primeQ;
			temp2 = temp2 * fp;
			temp2 = temp2 * primeP;
			temp = temp1 + temp2;
			temp = temp % modn;
		}
		rr = temp.outputSTR(r_length);
		for(int i = 0; i < r_length; ++i)
			out << rr[i];
		out << endl;
		delete[] rr;
	}

	delete[] rsach;
	temp.clear();
	temp1.clear();
	temp2.clear();
	out.close();
	in.close();
}

void rsa::EnCodingSpecial(int base)
{
	FILE* ffp;
	if( (ffp = fopen(rsamFile, "r") ) == NULL)
		return;

	fstream out;
	out.open(rsacFile, ios::out);

	int r_length;
	r_length = rsal * 3  / 20;

	BigInt temp;
	int rsa_leng;
	int count = 0;
	unsigned int rsa_int;
	char rsa_c;
	int i;
	int times = 0;

	while(! feof(ffp))
	{
		rsa_c = fgetc(ffp);
		if((rsa_c <= 'z' && rsa_c >= 'a') || (rsa_c <= 'Z' && rsa_c >= 'A'))
		{
			++count;
			if(rsa_c <= 'Z' && rsa_c >= 'A')
				rsa_int = ((unsigned int) ( rsa_c - 'A')) + 26;
			else
				rsa_int = ((unsigned int) ( rsa_c - 'a'));
			temp = temp * 100;
			temp += rsa_int;
			if(count == r_length)
			{
				++times;
				cout << "第 " << times << " 輪加密!";
				count = 0;
				temp = BImodexp2(temp, pubkey, modn);
				if(base == 10)
					rsach = temp.outputDEC(rsa_leng);
				else
					rsach = temp.outputHEX(rsa_leng);
				temp.setZero();
				for(i = 0; i < rsa_leng; ++i)
					out << rsach[i];
				delete[] rsach;
				out << endl;
			}
		}
	}
	temp = BImodexp2(temp, pubkey, modn);
	if(base == 10)
		rsach = temp.outputDEC(rsa_leng);
	else
		rsach = temp.outputHEX(rsa_leng);
	for(i = 0; i < rsa_leng; ++i)
			out << rsach[i];
	delete[] rsach;

	temp.clear();
	out.close();
	fclose(ffp);
}
void rsa::DeCodingSpecial(int choose, int base)
{
	fstream out;
	fstream in;
	in.open(rsacFile, ios::in);
	out.open(rsamFile, ios::out);

	BigInt temp;
	BigInt temp1;
	BigInt temp2;
	int r_length;
	char* rr;
	r_length = rsal * 3  / 10;
	rsach = new char[r_length + 5];
	rr = new char[r_length + 5];
	unsigned int rsa_int;
	int count;
	int times = 0;
	while(in >> rsach)
	{
		++times;
		cout << "第 " << times << " 輪解密!";
		if(base == 10)
			temp.loadDEC(rsach, strlen(rsach));
		else
			temp.loadHEX(rsach, strlen(rsach));

		if(choose == 3)
			temp = BImodexp2(temp, prikey, modn);

		else
		{
			temp1 = BImodexp2(temp, prikey, primeP);
			temp2 = BImodexp2(temp, prikey, primeQ);
			temp1 = temp1 * fq;
			temp1 = temp1 * primeQ;
			temp2 = temp2 * fp;
			temp2 = temp2 * primeP;
			temp = temp1 + temp2;
			temp = (temp % modn);
		}   
		count = 0;
		while(! temp.BIlisZero())
		{
			rsa_int = temp % 100;
			temp = temp / 100;
			if(rsa_int >= 0 && rsa_int <= 25)
				rr[count ++] = (char)(rsa_int + ((unsigned int)'a'));
			else if(rsa_int >= 26 && rsa_int <= 51) 
				rr[count ++] = (char)(rsa_int + ((unsigned int)'A') - 26);
		}
		for(int i = 0; i < count; ++i)
			out << rr[count - i - 1];
	}

	delete[] rr;
	delete[] rsach;
	temp.clear();
	temp1.clear();
	temp2.clear();
	out.close();
	in.close();
}

#endif

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕免费在线观看视频一区| 一区二区三区日韩| 欧美一区二区三区喷汁尤物| 欧美综合色免费| eeuss鲁片一区二区三区 | 色婷婷激情综合| 99精品1区2区| 色综合天天性综合| 日本韩国视频一区二区| 91黄色免费观看| 欧美日韩一区二区三区不卡 | 欧美高清在线一区| 国产精品情趣视频| 国产精品欧美综合在线| 国产精品毛片无遮挡高清| 中文字幕精品三区| 日韩久久一区二区| 一区二区三区不卡在线观看| 亚洲一级片在线观看| 亚洲成在人线在线播放| 日韩高清不卡在线| 精品一区二区久久久| 国产一区二区三区视频在线播放| 国产一区二区三区av电影 | 欧美片网站yy| 欧美一级专区免费大片| 精品福利av导航| 国产婷婷一区二区| 亚洲色图在线看| 亚洲一区免费视频| 美女在线一区二区| 国产精品亚洲视频| 在线观看免费一区| 欧美丰满高潮xxxx喷水动漫| 国产欧美视频在线观看| 国产伦精品一区二区三区免费| 国产精品18久久久久| 成人免费视频一区| 色94色欧美sute亚洲线路二| 欧美日韩aaa| 久久精品这里都是精品| 亚洲女同女同女同女同女同69| 午夜亚洲福利老司机| 经典三级视频一区| 色丁香久综合在线久综合在线观看 | 国产成人亚洲综合色影视| 99久久精品99国产精品| 在线成人午夜影院| 中文字幕欧美日本乱码一线二线| 洋洋av久久久久久久一区| 另类小说图片综合网| 懂色中文一区二区在线播放| 欧美午夜精品免费| 久久婷婷一区二区三区| 一区二区三区四区中文字幕| 久久国产精品免费| 色哟哟一区二区| 精品国产百合女同互慰| 亚洲欧美偷拍另类a∨色屁股| 婷婷丁香激情综合| 91香蕉视频mp4| 精品99一区二区| 亚洲国产乱码最新视频| 91在线看国产| 成人综合婷婷国产精品久久蜜臀| 91视频观看视频| 日韩一级高清毛片| 日本大胆欧美人术艺术动态| 国产伦精品一区二区三区免费 | 91精品国产欧美日韩| 日韩精品中文字幕在线不卡尤物 | 国产人久久人人人人爽| 一区二区三区精品视频在线| 国内精品国产成人| 欧美日韩一区不卡| 国产精品水嫩水嫩| 日韩高清中文字幕一区| 色猫猫国产区一区二在线视频| 欧美成人精品福利| 亚洲国产综合人成综合网站| 高清不卡一二三区| 日韩视频免费观看高清在线视频| 一区二区三区中文字幕电影| 高清在线不卡av| 欧美精品一区二区精品网| 水野朝阳av一区二区三区| 在线视频国内自拍亚洲视频| 中文字幕制服丝袜一区二区三区| 国产一区视频在线看| 欧美一区二区三区免费| 亚洲va欧美va国产va天堂影院| 99精品欧美一区二区蜜桃免费| 久久亚洲免费视频| 久久er99热精品一区二区| 欧美精品自拍偷拍| 亚洲国产精品尤物yw在线观看| eeuss鲁片一区二区三区| 国产日本欧洲亚洲| 成人蜜臀av电影| 国产欧美在线观看一区| 国产精品夜夜爽| 国产视频一区在线播放| 国产精品亚洲视频| 国产日产欧美一区| 成人免费高清视频| 中文字幕欧美一区| 99久久综合99久久综合网站| 中文字幕在线不卡一区二区三区| 国产乱子伦一区二区三区国色天香| 精品女同一区二区| 韩日欧美一区二区三区| 精品国产凹凸成av人导航| 国模无码大尺度一区二区三区| 日韩欧美国产一区在线观看| 美女视频一区二区三区| 日韩免费一区二区| 日本在线不卡视频| 精品国产一区二区三区久久影院| 激情综合色播五月| 久久精品视频免费| av在线不卡电影| 一区二区三区中文在线| 欧美最猛黑人xxxxx猛交| 肉肉av福利一精品导航| 日韩三级在线免费观看| 国产精品亚洲一区二区三区妖精| 国产精品久久99| 在线观看亚洲精品视频| 五月婷婷久久综合| 欧美成人综合网站| 高清不卡一区二区| 一区二区三区四区精品在线视频| 欧美三级视频在线| 久久精品国产99国产精品| 久久久www成人免费毛片麻豆 | 欧美色手机在线观看| 日本不卡一二三| 国产三级久久久| 欧美性xxxxxx少妇| 激情欧美一区二区三区在线观看| 国产精品国产三级国产专播品爱网| 91在线观看污| 日本欧美一区二区| 国产亚洲欧洲997久久综合| 99国产精品久久久久久久久久| 亚洲成人激情自拍| 久久久精品免费免费| 91免费在线播放| 蜜桃视频第一区免费观看| 国产精品美女久久久久久久久| 欧美性大战久久久久久久蜜臀| 精品一区二区综合| 亚洲欧美激情小说另类| 日韩美女在线视频| 91污片在线观看| 乱中年女人伦av一区二区| 中文字幕日韩av资源站| 91精品国产入口| 国产激情偷乱视频一区二区三区| 亚洲已满18点击进入久久| 精品成人在线观看| 一本到三区不卡视频| 久久精品国产在热久久| 亚洲欧洲日韩在线| 91精品国产综合久久久久久久久久| 国产91露脸合集magnet| 视频一区视频二区中文| 国产精品日韩成人| 日韩三级在线免费观看| 91精品91久久久中77777| 国产毛片精品视频| 午夜精品久久久久久久| 中文字幕亚洲一区二区va在线| 日韩欧美你懂的| 欧美在线一区二区| 99热国产精品| 狠狠色狠狠色综合系列| 午夜电影一区二区三区| 一区二区在线观看视频在线观看| 精品国产伦理网| 欧美精品第一页| 色噜噜偷拍精品综合在线| 国产成人精品亚洲777人妖| 免费成人在线网站| 亚洲自拍偷拍av| 日韩毛片视频在线看| 国产精品私房写真福利视频| 26uuu国产电影一区二区| 正在播放亚洲一区| 欧美无砖砖区免费| 一本色道综合亚洲| a美女胸又www黄视频久久| 国产精品资源站在线| 精品一区二区三区影院在线午夜| 午夜精品久久久久久久久久 | 蜜桃久久久久久| 午夜不卡av免费| 亚洲午夜精品在线| 一个色妞综合视频在线观看| 成人免费小视频|