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

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

?? rsa.h

?? rsa加密算法的vc實現
?? H
字號:
#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

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电影一区二区三区| 精品三级av在线| 免费精品99久久国产综合精品| 日韩视频一区在线观看| 色悠悠亚洲一区二区| 麻豆一区二区三区| 亚洲一区二区三区中文字幕 | 亚洲精品视频免费看| 日韩视频免费观看高清完整版| 99riav一区二区三区| 久久丁香综合五月国产三级网站| 一区二区在线观看视频| 国产亚洲精品aa午夜观看| 6080午夜不卡| 精品1区2区3区| 91小视频在线| 国产精品1区二区.| 蜜臀av性久久久久蜜臀aⅴ| 亚洲永久精品大片| 日韩美女啊v在线免费观看| 精品国产百合女同互慰| 666欧美在线视频| 欧美日韩久久一区二区| 色欧美乱欧美15图片| av电影在线观看完整版一区二区| 国产成人免费在线| 国产美女精品一区二区三区| 国产精品99久久久久久似苏梦涵| 日本aⅴ免费视频一区二区三区 | 亚洲乱码国产乱码精品精98午夜| 国产日韩欧美激情| 亚洲国产岛国毛片在线| 久久久久久久电影| 国产校园另类小说区| 久久婷婷综合激情| 精品999在线播放| 欧美精品一区二区在线观看| 久久影院视频免费| 欧美不卡一区二区三区四区| 日韩欧美国产麻豆| 精品国产乱码久久久久久夜甘婷婷 | 国产日韩欧美a| 精品成人一区二区三区四区| 日韩一级黄色片| 欧美videossexotv100| 日韩欧美国产精品| 欧美videofree性高清杂交| 欧美成人三级电影在线| 亚洲精品一区二区在线观看| 欧美sm极限捆绑bd| 久久精品视频免费| 中文字幕免费不卡| 亚洲精品中文字幕乱码三区| 亚洲精品久久久久久国产精华液| 亚洲激情自拍偷拍| 亚洲无线码一区二区三区| 日韩精品免费视频人成| 老司机一区二区| 丁香六月久久综合狠狠色| 91麻豆精品秘密| 欧美日韩在线观看一区二区| 91精品午夜视频| 久久久蜜臀国产一区二区| 国产精品三级av在线播放| 一区二区三区中文字幕| 亚洲v日本v欧美v久久精品| 青青草精品视频| 国产91高潮流白浆在线麻豆| 色系网站成人免费| 日韩一级在线观看| 中文字幕在线观看不卡| 亚洲专区一二三| 蜜桃精品视频在线观看| 国产69精品久久99不卡| 欧美日韩国产高清一区二区三区 | 成人av电影观看| 欧美日韩国产精选| 国产目拍亚洲精品99久久精品| 一区二区三区产品免费精品久久75 | 亚洲人被黑人高潮完整版| 同产精品九九九| 成人永久看片免费视频天堂| 欧美日韩一区二区在线观看| 久久久亚洲综合| 亚洲午夜久久久久中文字幕久| 精品一区二区三区视频| 色狠狠av一区二区三区| 欧美大片拔萝卜| 亚洲人成网站精品片在线观看| 毛片av一区二区三区| 色婷婷综合久久久久中文一区二区| 日韩欧美久久久| 亚洲综合色在线| 丰满少妇在线播放bd日韩电影| 欧美日韩国产一区二区三区地区| 国产日韩综合av| 日韩av电影天堂| 91在线免费播放| 久久久精品免费免费| 亚洲不卡av一区二区三区| 白白色 亚洲乱淫| 精品国产免费一区二区三区四区 | 久久99热99| 欧美性生活大片视频| 国产精品久久久久久久久搜平片| 日韩黄色一级片| 欧美综合色免费| 自拍偷拍欧美精品| 国产精品亚洲第一区在线暖暖韩国| 欧美色图12p| 亚洲图片你懂的| 国产精品77777竹菊影视小说| 日韩视频一区二区在线观看| 亚洲午夜在线观看视频在线| 不卡的av中国片| 国产精品水嫩水嫩| 国产在线视频一区二区| 日韩三级视频在线看| 亚洲国产日韩精品| 91蜜桃在线免费视频| 国产精品色婷婷久久58| 懂色av噜噜一区二区三区av| 精品va天堂亚洲国产| 免费观看一级欧美片| 欧美精品99久久久**| 亚洲电影中文字幕在线观看| 一道本成人在线| 亚洲精品久久7777| 在线日韩av片| 亚洲在线免费播放| 欧美在线不卡一区| 亚洲一区二区三区中文字幕| 欧美性大战xxxxx久久久| 一区二区三区资源| 欧美无砖砖区免费| 视频在线在亚洲| 欧美一级专区免费大片| 日韩福利电影在线观看| 91精品国产综合久久福利| 日本亚洲天堂网| 欧美videofree性高清杂交| 精品制服美女丁香| 久久久久久久综合色一本| 国产精品影音先锋| 国产精品久久久久久久午夜片| youjizz久久| 一区二区在线看| 91精品国产综合久久香蕉麻豆| 免费国产亚洲视频| 久久久不卡网国产精品二区| 国产1区2区3区精品美女| 国产精品黄色在线观看| 91小视频免费看| 日韩不卡在线观看日韩不卡视频| 亚洲精品在线观看视频| 成人黄色777网| 亚洲第一电影网| 精品久久久久香蕉网| 国产激情精品久久久第一区二区| 亚洲欧洲日韩av| 欧美在线观看视频一区二区| 毛片av一区二区| 国产精品成人免费精品自在线观看 | 裸体在线国模精品偷拍| 欧美高清在线视频| 欧洲精品一区二区| 麻豆精品久久久| 日韩美女啊v在线免费观看| 制服丝袜亚洲网站| 国产91色综合久久免费分享| 一区二区三区不卡视频在线观看| 欧美一级日韩免费不卡| 处破女av一区二区| 亚洲午夜免费福利视频| www欧美成人18+| 在线看国产日韩| 国产盗摄一区二区| 亚洲精品国产无天堂网2021| 精品国产欧美一区二区| 在线视频欧美精品| 国产一二三精品| 亚洲一区二区三区四区中文字幕| 亚洲精品一区在线观看| 91国产福利在线| 高清国产一区二区| 日韩激情av在线| 亚洲女性喷水在线观看一区| 欧美α欧美αv大片| 欧美亚洲尤物久久| 国产99精品视频| 毛片不卡一区二区| 亚洲一区免费视频| 国产精品毛片高清在线完整版| 在线播放日韩导航| 91年精品国产| 国产伦精一区二区三区| 日韩电影在线一区二区| 中文字幕一区二区三区不卡| 日韩精品中午字幕| 欧美亚洲动漫制服丝袜|