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

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

?? rsa_san.cpp

?? 開源項目openssl的源碼
?? CPP
字號:
#include "stdafx.h"
// This is a slow but easy RSA encryption class
// By sanicle,2005.12 
// 3mn@3mn.net

#include "stdio.h"
#include "rsa_san.h"

class Prime_factory_san
{
  unsigned np;
  unsigned *pl;
  public:
  Prime_factory_san();
  ~Prime_factory_san();
  vlong find_prime( vlong & start );
};

// prime factory implementation

static int is_probable_prime_san( const vlong &p )
{
  // Test based on Fermats theorem a**(p-1) = 1 mod p for prime p
  // For 1000 bit numbers this can take quite a while
  const rep = 4;
  const unsigned any[rep] = { 2,3,5,7 };
  for ( unsigned i=0; i<rep; i+=1 )
    if ( modexp( any[i], p-vlong(1), p ) != vlong(1) )
      return 0;
  return 1;
}

Prime_factory_san::Prime_factory_san()
{
  np = 0;
  unsigned NP = 200;
  pl = new unsigned[NP];

  // Initialise pl
  unsigned SS = 8*NP; // Rough estimate to fill pl
  char * b = new char[SS+1]; // one extra to stop search
  for (unsigned i=0;i<=SS;i+=1) b[i] = 1;
  unsigned p = 2;
  while (1)
  {
    // skip composites
    while ( b[p] == 0 ) p += 1;
    if ( p == SS ) break;
    pl[np] = p;
    np += 1;
    if ( np == NP ) break;
    // cross off multiples
    unsigned c = p*2;
    while ( c < SS )
    {
      b[c] = 0;
      c += p;
    }
    p += 1;
  }
  delete [] b;
}

Prime_factory_san::~Prime_factory_san()
{
  delete [] pl;
}

vlong Prime_factory_san::find_prime( vlong & start )
{
  unsigned SS = 1000; // should be enough unless we are unlucky
  char * b = new char[SS]; // bitset of candidate primes
  unsigned tested = 0;
  while (1)
  {
    unsigned i;
    for (i=0;i<SS;i++)
      b[i] = 1;
    for (i=0;i<np;i++)
    {
      unsigned p = pl[i];
      unsigned r = start % vlong(p); // not as fast as it should be - could do with special routine
      if (r) r = p - r;
      // cross off multiples of p
      while ( r < SS )
      {
        b[r] = 0;
        r += p;
      }
    }
    // now test candidates
    for (i=0;i<SS;i++)
    {
      if ( b[i] )
      {
        tested += 1;
        if ( is_probable_prime_san(start) )
          return start;
      }
      start += 1;
    }
  }
  delete [] b;
}



RSA_san::RSA_san()
{
	// init vars
	prime_table_use=0;
	prime_p_index=0;
	prime_q_index=1;
	
	char *tmp;
	tmp="1234567890qwertyuiopasdfghjklzxcvb";
	for(int i=0;i<36;i++)
	r1[i]=tmp[i];
	tmp="9876543210poiuytrewqlkjhgfdsamnbvc";
	for(i=0;i<36;i++)
	r2[i]=tmp[i];

	// find primes p q
	find_prime();
	// mul to get n
	n = p*q;
	// get a public key
	random_e();
	// calculate the private key
	calculate_d();
}

RSA_san::~RSA_san()
{
	
}

static vlong from_str_san( const char * s )
{
  vlong x = 0;
  while (*s)
  {
    x = x * vlong(256) + vlong((unsigned char)*s);
    s += 1;
  }
  return x;
}

void RSA_san::find_prime()
{
	// Choose primes
    Prime_factory_san pf;
	if (prime_table_use==0)
	{
		p = pf.find_prime( from_str_san(r1) );
		q = pf.find_prime( from_str_san(r2) );
	}
	else
	{
		p = prime_table[prime_p_index];
		q = prime_table[prime_q_index];
	}
    if ( p > q ) { vlong tmp = p; p = q; q = tmp; }
}

void RSA_san::random_e()
{
	e = 50001; // must be odd since p-1 and q-1 are even
    while ( gcd(p-vlong(1),e) != vlong(1) || gcd(q-vlong(1),e) != vlong(1) ) e += 2;
}

void RSA_san::calculate_d()
{
	d = modinv(e,(p-vlong(1))*(q-vlong(1)));
}
vlong RSA_san::encrypt( const vlong& x )
{
	return modexp(x,e,n);
}

vlong RSA_san::decrypt( const vlong& y )
{
	return modexp(y,d,n);
}

int RSA_san::RSA_san_en(char * s,unsigned n)
{
	vlong t = 0;
	result = 0;
	for(unsigned i=0;i<n;i++)
	{
		t = t * vlong(256) + vlong((unsigned char)*s);
		s += 1;
	}
	result=encrypt(t);
	return 1;
}

int RSA_san::RSA_san_en_byte(char b)
{
    result=0;
	result=encrypt(vlong((unsigned char)b));
	return 1;
}

int RSA_san::RSA_san_dn(char * s,unsigned n)
{
	vlong t = 0;
	result = 0;
	for(unsigned i=0;i<n;i++)
	{
		t = t * vlong(256) + vlong((unsigned char)*s);
		s += 1;
	}
	result=decrypt(t);
	return 1;
}

int RSA_san::RSA_san_dn_hexstring(char * s)
{
	unsigned i=0;
	vlong t = 0;
	result = 0;

	while(*s)
	{
		switch(*s)
		{
			case '0':i=0;break;
			case '1':i=1;break;
			case '2':i=2;break;
			case '3':i=3;break;
			case '4':i=4;break;
			case '5':i=5;break;
			case '6':i=6;break;
			case '7':i=7;break;
			case '8':i=8;break;
			case '9':i=9;break;
			case 'A':i=10;break;
			case 'B':i=11;break;
			case 'C':i=12;break;
			case 'D':i=13;break;
			case 'E':i=14;break;
			case 'F':i=15;break;
		}
		t = t * vlong(16) + vlong(i);
		s += 1;
	}
	result=decrypt(t);
	return 1;
}

int RSA_san::RSA_san_en_hexstring(char * s)
{
	unsigned i=0;
	vlong t = 0;
	result = 0;

	while(*s)
	{
		switch(*s)
		{
			case '0':i=0;break;
			case '1':i=1;break;
			case '2':i=2;break;
			case '3':i=3;break;
			case '4':i=4;break;
			case '5':i=5;break;
			case '6':i=6;break;
			case '7':i=7;break;
			case '8':i=8;break;
			case '9':i=9;break;
			case 'A':i=10;break;
			case 'B':i=11;break;
			case 'C':i=12;break;
			case 'D':i=13;break;
			case 'E':i=14;break;
			case 'F':i=15;break;
		}
		t = t * vlong(16) + vlong(i);
		s += 1;
	}
	result=encrypt(t);
	return 1;
}

int RSA_san::set_e(char * r)
{
	e = 0;
	while (*r)
	{
		e = e * vlong(256) + vlong((unsigned char)*r);
		r += 1;
	}
	if(e%vlong(2)==vlong(0))e-=1;
	while ( gcd(p-vlong(1),e) != vlong(1) || gcd(q-vlong(1),e) != vlong(1) ) e += 2;
	calculate_d();
	return 1;
}

int RSA_san::force_e(char * r,unsigned len)
{
	e = 0;
	p=0;q=0;
	for(unsigned i=0;i<len;i++)
	{
		e = e * vlong(256) + vlong((unsigned char)*(r+i));
	}
	return 1;
}

int RSA_san::force_d(char * r,unsigned len)
{
	d = 0;
	p=0;q=0;
	for(unsigned i=0;i<len;i++)
	{
		d = d * vlong(256) + vlong((unsigned char)*(r+i));
	}
	return 1;
}

int RSA_san::force_n(char * r,unsigned len)
{
	n = 0;
	p=0;q=0;
	for(unsigned i=0;i<len;i++)
	{
		n = n * vlong(256) + vlong((unsigned char)*(r+i));
	}
	return 1;
}

int RSA_san::update_pq(char * ra,char * rb)
{
	for(int i=0;i<35;i++)
	{	
		if(ra[i])r1[i]=ra[i];else r1[i]='A';
		if(rb[i])r2[i]=rb[i];else r2[i]='B'; //should provent string interrupt like this~
	}
	find_prime();
	n = p*q;
	if(e%vlong(2)==vlong(0))e-=1;
	while ( gcd(p-vlong(1),e) != vlong(1) || gcd(q-vlong(1),e) != vlong(1) ) e += 2;
	calculate_d();
	return 1;
}

char* RSA_san::string2hexstring(char * s)//,unsigned len)
{
	unsigned len=35; // only use this function like this in this situation:)
	char *ps;
	char *p;
	ps=new char[len*2+2];
	p=ps;
	for(unsigned i=0;i<len;i++)
	{
		p[0]='0';p[1]='0';
		sprintf(p,"%X",s[i]);
		if(p[1]=='\0')
		{
			p[1]=p[0];
			p[0]='0';
		}
		p+=2;
	}
	*p='\0';
	return ps;
}

char* RSA_san::hexstring2string(char * h)
{
	// if hexstring has 0 byte in it ,...be careful about '\0' 
	unsigned i,id;
	char *ph;
	char *t;
	id=0;
	i=(unsigned)strlen(h);
	t=new char[i];
	
	if(i%2)
	{
		ph=new char[i+1];
		*ph='0';
		ph++;
		for(unsigned j=0;j<i;j++)ph[j]=h[j];
		ph[i]='\0';
		ph--;
	}
	else ph=h;

	while(*ph)
	{
		switch(*ph)
		{
			case '0':i=0;break;
			case '1':i=16;break;
			case '2':i=32;break;
			case '3':i=48;break;
			case '4':i=64;break;
			case '5':i=80;break;
			case '6':i=96;break;
			case '7':i=112;break;
			case '8':i=128;break;
			case '9':i=144;break;
			case 'A':i=160;break;
			case 'B':i=176;break;
			case 'C':i=192;break;
			case 'D':i=208;break;
			case 'E':i=224;break;
			case 'F':i=240;break;
		}
		switch(*(ph+1))
		{
			case '0':i+=0;break;
			case '1':i+=1;break;
			case '2':i+=2;break;
			case '3':i+=3;break;
			case '4':i+=4;break;
			case '5':i+=5;break;
			case '6':i+=6;break;
			case '7':i+=7;break;
			case '8':i+=8;break;
			case '9':i+=9;break;
			case 'A':i+=10;break;
			case 'B':i+=11;break;
			case 'C':i+=12;break;
			case 'D':i+=13;break;
			case 'E':i+=14;break;
			case 'F':i+=15;break;
		}
		t[id]=i;
		id++;
		ph+=2;
	}
	t[id]='\0';
	return t;
}

char* RSA_san::vlong2hexstring( const vlong& v )
{
	unsigned z,t,j,l;
	char st[9];
	char *ps;
	j=0;
	z=v.get_z()-1;
	for(int i=z;i>=0;i--)
	{
		t=v.get(i);
		//t to hex and save in char s[]
		for(int m=0;m<8;m++)st[m]='\0';
		sprintf(st,"%X",t);
		l=(unsigned)strlen(st);
		if(l!=8)
		{
			for(int m=0;m<8;m++)st[m]='0';
			sprintf(st+8-l,"%X",t);
		}	
		for(int k=0;k<8;k++)
		{
			if(st[k]=='\0')st[k]='0';
			s[j]=st[k];
			j++;
		}
	}
	s[j]='\0';

	ps=s;
	while(*ps=='0')ps++;

	if(*ps=='\0')ps--;

	return ps;
}

/*
unsigned* RSA_san::vlong2ints( const vlong& v )
{
	unsigned z,j;
	j=0;
	z=v.get_z()-1;
	for(int i=z;i>=0;i--,j++)
	{
		u[j]=v.get(i);
	}
	u[j]=0;
	return u;
}
*/

char* RSA_san::vlong2shortints( const vlong& v )
{
	// use this function only when RSA result has no '\0' in it!
	unsigned z,j;
	char *pi;
	j=0;
	z=v.get_z()-1;
	for(int i=z;i>=0;i--,j++)
	{
		u[j]=v.get(i);
	}
	u[j]=0;
	pi=(char *)u;
	while(!*pi)pi++;
	return pi;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产伦一区二区三区观看体验 | 亚洲综合999| 高潮精品一区videoshd| 久久综合久久综合久久综合| 精品夜夜嗨av一区二区三区| 欧美videossexotv100| 国产最新精品精品你懂的| 久久久不卡网国产精品二区| 成人免费精品视频| 一个色妞综合视频在线观看| 欧美午夜不卡在线观看免费| 日本不卡123| 久久久久久97三级| 91影院在线免费观看| 亚洲精品国产第一综合99久久| 91亚洲午夜精品久久久久久| 亚洲高清在线视频| 欧美v日韩v国产v| 99久久国产综合色|国产精品| 夜夜嗨av一区二区三区网页 | 日韩精品在线一区二区| 国产一区二区调教| 中文字幕亚洲不卡| 4438x亚洲最大成人网| 国产精品91xxx| 亚洲欧美国产三级| 欧美一区二区私人影院日本| 国产黄人亚洲片| 亚洲精品第一国产综合野| 制服丝袜成人动漫| 丁香一区二区三区| 性做久久久久久免费观看欧美| 精品国产乱码久久| 色婷婷久久99综合精品jk白丝| 日本视频一区二区| |精品福利一区二区三区| 3751色影院一区二区三区| 国产成人激情av| 亚洲国产精品久久不卡毛片 | 欧美一区二区日韩| 97aⅴ精品视频一二三区| 蓝色福利精品导航| 一区二区三区资源| 久久精品人人爽人人爽| 欧美另类高清zo欧美| 成人激情午夜影院| 国精产品一区一区三区mba视频| 亚洲精品视频在线| 国产欧美日产一区| 日韩视频在线你懂得| 91黄视频在线观看| 国产成人欧美日韩在线电影| 日日摸夜夜添夜夜添精品视频| 中文成人av在线| 久久综合一区二区| 欧美另类高清zo欧美| 色综合色狠狠天天综合色| 国产精品亚洲一区二区三区妖精 | 免费人成在线不卡| 亚洲午夜精品网| 国产精品不卡一区| 欧美精品一区二区三区高清aⅴ | 91精品在线免费| 在线免费一区三区| 国产99久久久国产精品潘金网站| 日本成人在线不卡视频| 亚洲国产视频在线| 一区二区三区日本| 亚洲伦理在线免费看| 中文字幕一区二区三区视频| 国产视频在线观看一区二区三区| 日韩美女一区二区三区| 91精品在线免费| 欧美酷刑日本凌虐凌虐| 欧美视频在线一区二区三区| 91丨porny丨中文| 99精品视频在线观看| 不卡的av在线| www.久久精品| 99久久精品一区| 97久久超碰国产精品| 99视频精品全部免费在线| 成人精品视频一区二区三区尤物| 国产福利91精品一区二区三区| 国产麻豆精品一区二区| 国产一区二区在线观看视频| 国产一区二区免费在线| 国产在线一区二区综合免费视频| 美女视频网站久久| 韩国v欧美v日本v亚洲v| 国产成人综合在线| 成人av一区二区三区| 99re热这里只有精品免费视频| 95精品视频在线| 欧美三片在线视频观看| 欧美日韩一级大片网址| 91精品国产综合久久小美女| 91精品一区二区三区在线观看| 日韩欧美一级在线播放| www欧美成人18+| 国产精品久久毛片av大全日韩| 最新国产精品久久精品| 亚洲综合另类小说| 日韩激情一二三区| 韩日欧美一区二区三区| 国产jizzjizz一区二区| 一本一道综合狠狠老| 欧美日韩高清一区二区不卡| 制服丝袜中文字幕一区| 精品va天堂亚洲国产| 中文字幕精品一区| 一区二区国产视频| 久久精品国产成人一区二区三区| 国产一区二区免费视频| 一本到高清视频免费精品| 欧美日韩色综合| 久久精品亚洲一区二区三区浴池| 最新中文字幕一区二区三区| 天堂av在线一区| 成人午夜伦理影院| 欧美日韩卡一卡二| 欧美激情在线一区二区三区| 一区二区三区欧美视频| 国产在线精品视频| 在线免费av一区| 久久综合九色综合97婷婷女人| 亚洲欧美日韩国产中文在线| 免费不卡在线观看| 91老师片黄在线观看| 欧美白人最猛性xxxxx69交| 国产精品国产三级国产三级人妇 | 亚洲777理论| 丁香婷婷综合五月| 欧美一区二区三区免费在线看 | 欧美在线观看视频一区二区三区| 精品日韩一区二区三区| 亚洲激情男女视频| 粉嫩av一区二区三区| 91麻豆精品久久久久蜜臀| 国产精品不卡一区| 国产一区二区三区免费观看| 欧美日韩一级视频| 综合亚洲深深色噜噜狠狠网站| 国产在线精品免费| 91麻豆精品国产91久久久使用方法 | 欧美性感一类影片在线播放| 久久久久久免费| 免费视频一区二区| 欧美色网一区二区| 国产精品久久久久久亚洲毛片| 久久66热偷产精品| 欧美精品免费视频| 亚洲午夜久久久| 99久久久无码国产精品| 久久精品网站免费观看| 久久精品国产99国产| 91麻豆精品国产自产在线 | 99国产精品99久久久久久| 久久久久久麻豆| 国产自产2019最新不卡| 日韩一区二区影院| 日韩国产精品久久久久久亚洲| 欧美在线观看一区| 亚洲人成影院在线观看| av一区二区三区四区| 国产日产欧美一区| 国产成人免费在线观看| 久久久天堂av| 国产精品一区二区三区四区| 精品国产一区二区三区久久久蜜月| 亚洲福利一二三区| 欧美三级在线播放| 亚洲午夜免费电影| 欧美日韩国产影片| 日韩高清在线观看| 日韩一区和二区| 黄色资源网久久资源365| 精品成a人在线观看| 国产中文字幕一区| 久久久电影一区二区三区| 国产成人精品一区二区三区四区 | 亚洲人亚洲人成电影网站色| 成人白浆超碰人人人人| 中文字幕中文字幕在线一区| 99视频超级精品| 一区二区在线观看免费视频播放| 日本丰满少妇一区二区三区| 亚洲一区二区在线免费观看视频| 欧美在线视频你懂得| 亚洲a一区二区| 精品美女一区二区三区| 国产乱子轮精品视频| 国产精品福利一区| 日本道色综合久久| 青青国产91久久久久久| 精品久久久网站| 99国产欧美另类久久久精品| 一区二区三区**美女毛片| 欧美日韩一区三区四区| 久久99国产精品免费网站|