c語言寫rsa加密,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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
KYPT的頭像KYPT
上一篇 2024-11-04 17:51
下一篇 2024-11-04 17:51

相關推薦

  • AES加密解密演算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密演算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES演算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演著非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28
  • Python語言實現人名最多數統計

    本文將從幾個方面詳細介紹Python語言實現人名最多數統計的方法和應用。 一、Python實現人名最多數統計的基礎 1、首先,我們需要了解Python語言的一些基礎知識,如列表、字…

    編程 2025-04-28
  • Python作為中心語言,在編程中取代C語言的優勢和挑戰

    Python一直以其簡單易懂的語法和高效的編碼環境而著名。然而,它最近的發展趨勢表明Python的使用範圍已經從腳本語言擴展到了從Web應用到機器學習等廣泛的開發領域。與此同時,C…

    編程 2025-04-28
  • Python基礎語言

    Python作為一種高級編程語言擁有簡潔優雅的語法。在本文中,我們將從多個方面探究Python基礎語言的特點以及使用技巧。 一、數據類型 Python基礎數據類型包括整數、浮點數、…

    編程 2025-04-28

發表回復

登錄後才能評論