本文目錄一覽:
- 1、RSA加密解密演算法示例(C語言)
- 2、求正確的RSA加密解密演算法C語言的,多謝。
- 3、RSA加密演算法怎樣用C語言實現? 急急急!!!
- 4、如何用C語言來使用openssl rsa進行公鑰加密,已有公鑰和明文
- 5、rsa演算法c語言實現
- 6、如何用C語言實現RSA演算法?
RSA加密解密演算法示例(C語言)
#include stdlib.h
#include stdio.h
#include string.h
#include math.h
#include time.h
#define PRIME_MAX 200 // 生成素數範圍
#define EXPONENT_MAX 200 // 生成指數e範圍
#define Element_Max 127 // 加密單元的最大值,這裡為一個char, 即1Byte
char str_read[100]=”hello world !”; // 待加密的原文
int str_encrypt[100]; // 加密後的內容
char str_decrypt[100]; // 解密出來的內容
int str_read_len; // str_read 的長度
int prime1, prime2; // 隨機生成的兩個質數
int mod, eular; // 模數和歐拉數
int pubKey, priKey; // 公鑰指數和私鑰指數
// 生成隨機素數,實際應用中,這兩個質數越大,就越難破解。
int randPrime()
{
int prime, prime2, i;
next:
prime = rand() % PRIME_MAX; // 隨機產生數
if (prime = 1) goto next; // 不是質數,生成下一個隨機數
if (prime == 2 || prime == 3) return prime;
prime2 = prime / 2; // prime=4, prime2 的平方必定大於 prime , 因此只檢查小於等於prime2的數
for (i = 2; i = prime2; i++) // 判斷是否為素數
{
if (i * i prime) return prime;
if (prime % i == 0) goto next; // 不是質數,生成下一個隨機數
}
}
// 歐幾里德演算法,判斷a,b互質
int gcd(int a, int b)
{
int temp;
while (b != 0) {
temp = b;
b = a % b;
a = temp;
}
return a;
}
//生成公鑰指數,條件是 1 e 歐拉數,且與歐拉數互質。
int randExponent()
{
int e;
while (1)
{
e = rand() % eular; if (e EXPONENT_MAX) break;
}
while (1)
{
if (gcd(e, eular) == 1) return e; e = (e + 1) % eular; if (e == 0 || e EXPONENT_MAX) e = 2;
}
}
//生成私鑰指數
int inverse()
{
int d, x;
while (1)
{
d = rand() % eular;
x = pubKey * d % eular;
if (x == 1)
{
return d;
}
}
}
//加密函數
void jiami()
{
str_read_len = strlen(str_read); //從參數表示的地址往後找,找到第一個’\0’,即串尾。計算’\0’至首地址的「距離」,即隔了幾個字元,從而得出長度。
printf(“密文是:”);
for (int i = 0; i str_read_len; i++)
{
int C = 1; int a = str_read[i], b = a % mod;
for (int j = 0; j pubKey; j++) //實現加密
{
C = (C*b) % mod;
}
str_encrypt[i] = C;
printf(“%d “, str_encrypt[i]);
}
printf(“\n”);
}
//解密函數
void jiemi()
{
int i=0; for (i = 0; i str_read_len; i++)
{
int C = 1; int a = str_encrypt[i], b=a%mod;
for (int j = 0; j priKey; j++)
{
C = (C * b) % mod;
}
str_decrypt[i] = C;
}
str_decrypt[i] = ‘\0’; printf(“解密文是:%s \n”, str_decrypt);
}
int main()
{
srand(time(NULL));
while (1)
{
prime1 = randPrime(); prime2 = randPrime(); printf(“隨機產生兩個素數:prime1 = %d , prime2 = %d “, prime1, prime2);
mod = prime1 * prime2; printf(“模數:mod = prime1 * prime2 = %d \n”, mod); if (mod Element_Max) break; // 模數要大於每個加密單元的值
}
eular = (prime1 – 1) * (prime2 – 1); printf(“歐拉數:eular=(prime1-1)*(prime2-1) = %d \n”, eular);
pubKey = randExponent(); printf(“公鑰指數:pubKey = %d\n”, pubKey);
priKey = inverse(); printf(“私鑰指數:priKey = %d\n私鑰為 (%d, %d)\n”, priKey, priKey, mod);
jiami(); jiemi();
return 0;
}
求正確的RSA加密解密演算法C語言的,多謝。
//rsa.h
#include stdio.h
#define MAX_NUM 63001
#define MAX_PRIME 251
//! 返回代碼
#define OK 100
#define ERROR_NOEACHPRIME 101
#define ERROR_NOPUBLICKEY 102
#define ERROR_GENERROR 103
unsigned int MakePrivatedKeyd( unsigned int uiP, unsigned int uiQ );
unsigned int GetPrivateKeyd( unsigned int iWhich );
unsigned int MakePairkey( unsigned int uiP, unsigned int uiQ, unsigned int uiD );
unsigned int GetPairKey( unsigned int d, unsigned int e );
void rsa_encrypt( int n, int e, char *mw, int iLength, int *cw );
void rsa_decrypt( int n, int d, int *cw, int cLength, char *mw );
void outputkey();
//rsa.c
#include “rsa.h”
//! 保存私鑰d集合
struct pKeyset
{
unsigned int set[ MAX_NUM ];
unsigned int size;
}pset;
//! 保存公、私鑰對
struct pPairkey
{
unsigned int d;
unsigned int e;
unsigned int n;
}pairkey;
// 名稱:isPrime
// 功能:判斷兩個數是否互質
// 參數:m: 數a; n: 數b
// 返回:m、n互質返回true; 否則返回false
bool isPrime( unsigned int m, unsigned int n )
{
unsigned int i=0;
bool Flag = true;
if( m2 || n2 )
return false;
unsigned int tem = ( m n ) ? n : m;
for( i=2; i=tem Flag; i++ )
{
bool mFlag = true;
bool nFlag = true;
if( m % i == 0 )
mFlag = false;
if( n % i == 0 )
nFlag = false;
if( !mFlag !nFlag )
Flag = false;
}
if( Flag )
return true;
else
return false;
}
// 名稱:MakePrivatedKeyd
// 功能:由素數Q、Q生成私鑰d
// 參數:uiP: 素數P; uiQ: 素數Q
// 返回:私鑰d
unsigned int MakePrivatedKeyd( unsigned int uiP, unsigned int uiQ )
{
unsigned int i=0;
//! 得到所有與z互質的數( 私鑰d的集合 )
unsigned int z = ( uiP -1 ) * ( uiQ -1 );
pset.size = 0;
for( i=0; iz; i++ )
{
if( isPrime( i, z ) )
{
pset.set[ pset.size++ ] = i;
}
}
return pset.size;
}
// 名稱:MakePairKey
// 功能:生成RSA公、私鑰對
// 參數:uiP: 素數P; uiQ: 素數Q; uiD: 私鑰d
// 返回:錯誤代碼
unsigned int MakePairkey( unsigned int uiP, unsigned int uiQ, unsigned int uiD )
{
bool bFlag = true;
unsigned int i = 0, e;
unsigned int z = ( uiP-1 ) * ( uiQ-1 );
unsigned int d = pset.set[uiD];
//d=uiD;
if( !isPrime( z, d ) )
return ERROR_NOEACHPRIME;
for( i=2; iz; i++ )
{
if( (i*d)%z == 1 )
{
e = i;
bFlag = false;
}
}
if( bFlag )
return ERROR_NOPUBLICKEY;
if( (d*e)%z != 1 )
ERROR_GENERROR;
pairkey.d = d;
pairkey.e = e;
pairkey.n = uiP * uiQ;
return OK;
}
// 名稱:GetPairKey
// 功能:對外提供介面,獲得公、私鑰對
// 參數:uiP: 素數P; uiQ: 素數Q; uiD: 私鑰d
// 返回:
unsigned int GetPairKey( unsigned int d, unsigned int e )
{
d = pairkey.d;
e = pairkey.e;
return pairkey.n;
}
// 名稱:GetPrivateKeyd
// 功能:對外提供介面,由用戶選擇ID得以私鑰d
// 參數:iWhich: 用戶選擇私鑰d的ID
// 返回:私鑰d值
unsigned int GetPrivateKeyd( unsigned int iWhich )
{
if( pset.size = iWhich )
return pset.set[ iWhich ];
else
return 0;
}
// 名稱:rsa_encrypt
// 功能:RSA加密運算
// 參數:n: 公鑰n; e: 公鑰e; mw: 加密明文; iLength: 明文長度; cw: 密文輸出
// 返回:無
void rsa_encrypt( int n, int e, char *mw, int mLength, int *cw )
{
int i=0, j=0;
__int64 temInt = 0;
for( i=0; imLength; i++ )
{
temInt = mw[i];
if( e!=0 )
{
for( j=1; je; j++ )
{
temInt = ( temInt * mw[i] ) % n;
}
}
else
{
temInt = 1;
}
cw[i] = (int)temInt;
}
}
// 名稱:rsa_decrypt
// 功能:RSA解密運算
// 參數:n: 私鑰n; d: 私鑰d; cw: 密文; cLength: 密文長度; mw: 明文輸出
// 返回:無
void rsa_decrypt( int n, int d, int *cw, int cLength, char *mw )
{
int i=0, j=-1;
__int64 temInt = 0;
for( i=0; icLength/4; ++i )
{
mw[i] = 0;
temInt = cw[i];
if( d != 0 )
{
for( j=1; jd; j++ )
{
temInt = (__int64)( temInt * cw[i] ) % n;
}
}
else
{
temInt = 1;
}
mw[i] = (char)temInt;
}
}
void outputkey()
{
printf(“PublicKey(e,n): (%d,%d)\n”,pairkey.e,pairkey.n);
printf(“PrivateKey(d,n): (%d,%d)\n”,pairkey.d,pairkey.n);
}
//main.c
// 工程:RSA
// 功能:RSA加、解密文件
// 作者:jlcss|ExpNIS
#include stdio.h
#include afxwin.h
#include math.h
#include “rsa.h”
#define DECRYPT_FILE “RSA加密密文.txt”
#define ENCRYPT_FILE “RSA解密明文.txt”
//! 約束文件最大2M
#define MAX_FILE 1024*1024*2
// 名稱:usage
// 功能:幫助信息
// 參數:應用程序名稱
// 返回:提示信息
void Usage( const char *appname )
{
printf( “\n\tusage:rsa -k 素數P 素數Q\n” );
printf( “\tusage: rsa -e 明文文件 公鑰e 公鑰n\n” );
printf( “\tusage: rsa -d 密文文件 私鑰d 私鑰n\n” );
}
// 名稱:IsNumber
// 功能:判斷數字字元數組
// 參數:strNumber:字元數組
// 返回:數字字組數組返回true,否則返回false;
bool IsNumber( const char *strNumber )
{
unsigned int i;
if( !strNumber )
return false;
for ( i = 0 ; i strlen(strNumber) ; i++ )
{
if ( strNumber[i] ‘0’ || strNumber[i] ‘9’ )
return false;
}
return true;
}
// 名稱:IsPrimeNumber
// 功能:判斷素數
// 參數:num: 輸入整數
// 返回:素數返回true,否則返回false;
bool IsPrimeNumber( unsigned int num )
{
unsigned int i;
if( num = 1 )
return false;
unsigned int sqr = (unsigned int)sqrt((double)num);
for( i = 2; i = sqr; i++ )
{
if( num % i == 0 )
return false;
}
return true;
}
// 名稱:FileIn
// 功能:讀取磁碟文件到內存
// 參數:strFile:文件名稱;inBuff:指向文件內容緩衝區
// 返回:實際讀取內容大小(位元組)
int FileIn( const char *strFile, unsigned char *inBuff )
{
int iFileLen=0, iBuffLen=0;
//! 打開密文文件
CFile file( strFile, CFile::modeRead );
iFileLen = ( int )file.GetLength();
if( iFileLenMAX_FILE )
{
printf( “文件長度不能大於 %dM,!\n”, MAX_FILE/(1024*1024) );
goto out;
}
iBuffLen = iFileLen;
inBuff = new unsigned char[iBuffLen];
if( !inBuff )
goto out;
ZeroMemory( inBuff, iBuffLen );
file.Read( inBuff, iFileLen );
file.Close();
out:
return iBuffLen;
}
// 名稱:FileOut
// 功能:加/解密結果輸出到當前目錄磁碟文件中
// 參數:strOut指向輸出字元緩衝區,輸出大小len,strFile為輸出文件
// 返回:無
void FileOut( const void *strOut, int len, const char *strFile )
{
//! 輸出到文件
CFile outfile( strFile , CFile::modeCreate | CFile::modeWrite );
outfile.Write( strOut , len );
outfile.Close();
}
// 名稱:CheckParse
// 功能:校驗應用程序入口參數
// 參數:argc等於main主函數argc參數,argv指向main主函數argv參數
// 返回:若參數合法返回true,否則返回false
// 備註:簡單的入口參數校驗
bool CheckParse( int argc, char** argv )
{
bool bRes = false;
if( argc != 4 argc != 5 )
goto out;
if( argc == 4 argv[1][1] == ‘k’ )
{
//! 生成公、私鑰對
if( !IsNumber( argv[2] ) ||
!IsNumber( argv[3] ) ||
atoi( argv[2] ) MAX_PRIME ||
atoi( argv[3] ) MAX_PRIME )
goto out;
}
else if( (argc == 5) (argv[1][1] == ‘e’ || argv[1][1] == ‘d’) )
{
//! 加密、解密操作
if( !IsNumber( argv[3] ) ||
!IsNumber( argv[4] ) ||
atoi( argv[3] ) MAX_NUM ||
atoi( argv[4] ) MAX_NUM )
goto out;
}
else
Usage(*argv);
bRes = true;
out:
return bRes;
}
// 名稱:kOption1
// 功能:程序k選項操作:由素數P、Q生成私鑰d集合
// 參數:uiP: 程序入口參數P; uiQ: 程序入口參數Q
// 返回:執行正確返回生成私鑰數目,否則返回0
unsigned int kOption1( unsigned int uiP, unsigned int uiQ )
{
unsigned int uiRes = 0;
if( !IsPrimeNumber( uiP ) )
{
printf( “P輸入錯誤,P必須為(0, %d]素數”, MAX_PRIME );
return uiRes;
}
if( !IsPrimeNumber( uiQ ) )
{
printf( “Q輸入錯誤,Q必須為(0, %d]素數”, MAX_PRIME );
return uiRes;
}
if( uiP == uiQ )
{
printf( “素數P與素數Q相同,很容易根據公鑰n開平方得出素數P和Q,這種加密不安全,請更換素數!\n” );
return uiRes;
}
printf( “正在生成私鑰d集合……\n” );
uiRes = MakePrivatedKeyd( uiP, uiQ );
return uiRes;
}
//! 程序主函數
int main( int argc, char **argv )
{
unsigned int p , q , d , n , e;//two prime p q, public key(n, e) , private key(n , d)
CheckParse(argc, argv );
d=4828; //uid
if(argc == 4)
{
p = atoi( argv[2] );
q = atoi( argv[3] );
MakePrivatedKeyd(p, q);
MakePairkey(p, q, d );
outputkey();
}
else if(argc == 5)
{
char FileName[20];
strcpy(FileName, argv[2]);
int len;
if(argv[1][1] == ‘e’ )
{
unsigned char *inBuffer=(unsigned char *)malloc(MAX_FILE); //輸入緩衝區
int *cw=(int *)malloc(MAX_FILE);
len = FileIn(FileName , inBuffer);
e = atoi(argv[3]);
n = atoi(argv[4]);
rsa_encrypt( n, e, (char *)inBuffer, len, cw );
FileOut( cw, 4*len, DECRYPT_FILE );
}
else if(argv[1][1] == ‘d’)
{
char *Buffer=(char *)malloc(MAX_FILE); //輸入緩衝區
int *cw=(int *)malloc(MAX_FILE);
len = FileIn(FileName, (unsigned char *)cw);
d = atoi(argv[3]);
n = atoi(argv[4]);
rsa_decrypt( n, d, cw, len, Buffer );
FileOut( Buffer, len/4, ENCRYPT_FILE );
}
}
return 0;
}
RSA加密演算法怎樣用C語言實現? 急急急!!!
/*數據只能是大寫字母組成的字元串。
加密的時候,輸入Y,然後輸入要加密的文本(大寫字母)
解密的時候,輸入N,然後輸入一個整數n表示密文的個數,然後n個整數表示加密時候得到的密文。
*/
/*RSA algorithm */
#include stdio.h
#include string.h
#include stdlib.h
#define MM 7081
#define KK 1789
#define PHIM 6912
#define PP 85
typedef char strtype[10000];
int len;
long nume[10000];
int change[126];
char antichange[37];
void initialize()
{ int i;
char c;
for (i = 11, c = ‘A’; c = ‘Z’; c ++, i ++)
{ change[c] = i;
antichange[i] = c;
}
}
void changetonum(strtype str)
{ int l = strlen(str), i;
len = 0;
memset(nume, 0, sizeof(nume));
for (i = 0; i l; i ++)
{ nume[len] = nume[len] * 100 + change[str[i]];
if (i % 2 == 1) len ++;
}
if (i % 2 != 0) len ++;
}
long binamod(long numb, long k)
{ if (k == 0) return 1;
long curr = binamod (numb, k / 2);
if (k % 2 == 0)
return curr * curr % MM;
else return (curr * curr) % MM * numb % MM;
}
long encode(long numb)
{ return binamod(numb, KK);
}
long decode(long numb)
{ return binamod(numb, PP);
}
main()
{ strtype str;
int i, a1, a2;
long curr;
initialize();
puts(“Input ‘Y’ if encoding, otherwise input ‘N’:”);
gets(str);
if (str[0] == ‘Y’)
{ gets(str);
changetonum(str);
printf(“encoded: “);
for (i = 0; i len; i ++)
{ if (i) putchar(‘-‘);
printf(” %ld “, encode(nume[i]));
}
putchar(‘\n’);
}
else
{ scanf(“%d”, len);
for (i = 0; i len; i ++)
{ scanf(“%ld”, curr);
curr = decode(curr);
a1 = curr / 100;
a2 = curr % 100;
printf(“decoded: “);
if (a1 != 0) putchar(antichange[a1]);
if (a2 != 0) putchar(antichange[a2]);
}
putchar(‘\n’);
}
putchar(‘\n’);
system(“PAUSE”);
return 0;
}
/*
測試:
輸入:
Y
FERMAT
輸出:
encoded: 5192 – 2604 – 4222
輸入
N
3 5192 2604 4222
輸出
decoded: FERMAT
*/
如何用C語言來使用openssl rsa進行公鑰加密,已有公鑰和明文
1. 本程序使用2048位密鑰對,每次加密時,原始數據的最大長度為245位元組,加密後的密文長度為256位元組.(採用打PADDING 的加密方式)
2. 如果所加密數據長度大於245位元組,請分多次加密,後將密文按順序存儲;解密時,每次讀取256位元組,進行解密,將解密後的數據依次按順序存儲,即可還原原始數據.
#include stdio.h
#include stdlib.h
#include string.h
#include errno.h
#include openssl/rsa.h
#include openssl/pem.h
#include openssl/err.h
#define OPENSSLKEY “test.key”
#define PUBLICKEY “test_pub.key”
#define BUFFSIZE 1024
char *my_encrypt(char *str, char *path_key); //加密
char *my_decrypt(char *str, char *path_key); //解密
int main(void)
{
char *source = “i like dancing !!!”;
char *ptf_en, *ptf_de;
printf(“source is :%s\n”, source);
//1.加密
ptf_en = my_encrypt(source, PUBLICKEY);
if (ptf_en == NULL){
return 0;
}else{
printf(“ptf_en is :%s\n”, ptf_en);
}
//2.解密
ptf_de = my_decrypt(ptf_en, OPENSSLKEY);
if (ptf_de == NULL){
return 0;
}else{
printf(“ptf_de is :%s\n”, ptf_de);
}
if(ptf_en) free(ptf_en);
if(ptf_de) free(ptf_de);
return 0;
}
//加密
char *my_encrypt(char *str, char *path_key)
{
char *p_en = NULL;
RSA *p_rsa = NULL;
FILE *file = NULL;
int lenth = 0; //flen為源文件長度, rsa_len為秘鑰長度
//1.打開秘鑰文件
if((file = fopen(path_key, “rb”)) == NULL)
{
perror(“fopen() error 111111111 “);
goto End;
}
//2.從公鑰中獲取 加密的秘鑰
if((p_rsa = PEM_read_RSA_PUBKEY(file, NULL,NULL,NULL )) == NULL)
{
ERR_print_errors_fp(stdout);
goto End;
}
lenth = strlen(str);
p_en = (char *)malloc(256);
if(!p_en)
{
perror(“malloc() error 2222222222”);
goto End;
}
memset(p_en, 0, 256);
//5.對內容進行加密
if(RSA_public_encrypt(lenth, (unsigned char*)str, (unsigned char*)p_en, p_rsa, RSA_PKCS1_PADDING) 0)
{
perror(“RSA_public_encrypt() error 2222222222”);
goto End;
}
End:
//6.釋放秘鑰空間, 關閉文件
if(p_rsa) RSA_free(p_rsa);
if(file) fclose(file);
return p_en;
}
//解密
char *my_decrypt(char *str, char *path_key)
{
char *p_de = NULL;
RSA *p_rsa = NULL;
FILE *file = NULL;
//1.打開秘鑰文件
file = fopen(path_key, “rb”);
if(!file)
{
perror(“fopen() error 22222222222”);
goto End;
}
//2.從私鑰中獲取 解密的秘鑰
if((p_rsa = PEM_read_RSAPrivateKey(file, NULL,NULL,NULL )) == NULL)
{
ERR_print_errors_fp(stdout);
goto End;
}
p_de = (char *)malloc(245);
if(!p_de)
{
perror(“malloc() error “);
goto End;
}
memset(p_de, 0, 245);
//5.對內容進行加密
if(RSA_private_decrypt(256, (unsigned char*)str, (unsigned char*)p_de, p_rsa, RSA_PKCS1_PADDING) 0)
{
perror(“RSA_public_encrypt() error “);
goto End;
}
End:
//6.釋放秘鑰空間, 關閉文件
if(p_rsa) RSA_free(p_rsa);
if(file) fclose(file);
return p_de;
}
rsa演算法c語言實現
程序修改如下:
(主要是你的循環寫的不對,輸入的字元應該-‘0’才能與正常的數字對應)
#includestdio.h
#includemath.h
int
candp(int
a,int
b,int
c)
{int
r=1;
int
s;
int
i=1;
for(i=1;i=b;i++)r=r*a;
printf(“%d\
“,r);
s=r%c;
printf(“%d\
“,s);
return
s;}
void
main()
{
int
p,q,e,d,m,n,t,c,r
;
char
s;
printf(“please
input
the
p,q:”);
scanf(“%d%d”,p,q);
n=p*q;
t=(p-1)*(q-1);
printf(“the
n
is
%12d\
“,n);
printf(“please
input
the
e:”);
scanf(“%d”,e);
while(e1||en)
//此處修改為while循環
{
printf(“e
is
error,please
input
again:”);
scanf(“%d”,e);
}
d=1;
while(((e*d)%t)!=1)
d++;
printf(“then
caculate
out
that
the
d
is
%d\
“,d);
printf(“the
cipher
please
input
1\
“);
printf(“the
plain
please
input
2\
“);
scanf(“%c”,s);
while((s-‘0’)!=1(s-‘0’)!=2)
//消除後面的getchar()
此處增加while循環注意括弧內的字元
{scanf(“%c”,s);}
switch(s-‘0’)
{
case
1:printf(“intput
the
m:”);
scanf(“%d”,m);
c=candp(m,e,n);
printf(“the
plain
is
%d\
“,c);break;
case
2:printf(“input
the
c:”);
scanf(“%d”,c);
m=candp(c,d,n);
printf(“the
cipher
is
%8d\
“,m);
break;
}
}
如何用C語言實現RSA演算法?
上學期交的作業,已通過老師在運行時間上的測試\x0d\x0a#include \x0d\x0a#include \x0d\x0a\x0d\x0aunsigned long prime1,prime2,ee;\x0d\x0a\x0d\x0aunsigned long *kzojld(unsigned long p,unsigned long q) //擴展歐幾里得演算法求模逆\x0d\x0a{\x0d\x0aunsigned long i=0,a=1,b=0,c=0,d=1,temp,mid,ni[2];\x0d\x0amid=p;\x0d\x0awhile(mid!=1)\x0d\x0a{\x0d\x0awhile(pq)\x0d\x0a{p=p-q;mid=p;i++;}\x0d\x0a a=c*(-1)*i+a;b=d*(-1)*i+b;\x0d\x0atemp=a;a=c;c=temp;\x0d\x0atemp=b;b=d;d=temp;\x0d\x0atemp=p;p=q;q=temp;\x0d\x0ai=0;\x0d\x0a}\x0d\x0ani[0]=c;ni[1]=d;\x0d\x0areturn(ni);\x0d\x0a}\x0d\x0a\x0d\x0aunsigned long momi(unsigned long a,unsigned long b,unsigned long p) //模冪演算法\x0d\x0a{\x0d\x0aunsigned long c;\x0d\x0ac=1;\x0d\x0aif(ap) a=a%p;\x0d\x0aif(bp) b=b%(p-1);\x0d\x0awhile(b!=0)\x0d\x0a{\x0d\x0awhile(b%2==0)\x0d\x0a{\x0d\x0ab=b/2;\x0d\x0aa=(a*a)%p;\x0d\x0a}\x0d\x0ab=b-1;\x0d\x0ac=(a*c)%p;\x0d\x0a}\x0d\x0areturn(c);\x0d\x0a}\x0d\x0a\x0d\x0avoid RSAjiami() //RSA加密函數\x0d\x0a{\x0d\x0aunsigned long c1,c2;\x0d\x0aunsigned long m,n,c;\x0d\x0an=prime1*prime2;\x0d\x0asystem(“cls”);\x0d\x0aprintf(“Please input the message:\n”);\x0d\x0ascanf(“%lu”,m);getchar();\x0d\x0ac=momi(m,ee,n);\x0d\x0aprintf(“The cipher is:%lu”,c);\x0d\x0areturn;\x0d\x0a}\x0d\x0a\x0d\x0avoid RSAjiemi() //RSA解密函數\x0d\x0a{\x0d\x0aunsigned long m1,m2,e,d,*ni;\x0d\x0aunsigned long c,n,m,o;\x0d\x0ao=(prime1-1)*(prime2-1);\x0d\x0an=prime1*prime2;\x0d\x0asystem(“cls”);\x0d\x0aprintf(“Please input the cipher:\n”);\x0d\x0ascanf(“%lu”,c);getchar();\x0d\x0ani=kzojld(ee,o);\x0d\x0ad=ni[0];\x0d\x0am=momi(c,d,n);\x0d\x0aprintf(“The original message is:%lu”,m);\x0d\x0areturn;\x0d\x0a}\x0d\x0a\x0d\x0avoid main()\x0d\x0a{unsigned long m;\x0d\x0achar cho;\x0d\x0aprintf(“Please input the two prime you want to use:\n”);\x0d\x0aprintf(“P=”);scanf(“%lu”,prime1);getchar();\x0d\x0aprintf(“Q=”);scanf(“%lu”,prime2);getchar();\x0d\x0aprintf(“E=”);scanf(“%lu”,ee);getchar();\x0d\x0aif(prime1
原創文章,作者:KYPT,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/149151.html