您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“c語(yǔ)言中的文件加密與解密怎么實(shí)現(xiàn)”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“c語(yǔ)言中的文件加密與解密怎么實(shí)現(xiàn)”吧!
本程序是一個(gè)c語(yǔ)言的大作業(yè)的一部分
是簡(jiǎn)單的基于給定密鑰實(shí)現(xiàn)的加密解密程序
文件的傳輸會(huì)有明文和密文的區(qū)別,明文發(fā)送是不安全的。
本題目實(shí)現(xiàn)對(duì)文件的加密和解密操作,采用的加密算法是根據(jù)密鑰將明文中的字母置換為其它字母,所有字母不區(qū)分大小寫(xiě),不考慮除英文字母外的字符。
例如:
明文是:They will arrive tomorrow,密鑰k=Monday
① 設(shè)置英文字母與0到25有如下的對(duì)應(yīng)關(guān)系:
A | B | C | D | E | F | G | H | I | J | K | L | M | N | O | P | Q | R | S | T | U | V | W | X | Y | Z |
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 |
②依據(jù)上述對(duì)應(yīng)關(guān)系將明文和密鑰轉(zhuǎn)化為一組數(shù)字:
k=(12,14,13,3,0,24)
m=(19,7,4,24,22,8,11,11,0,17,17,8,21,4,19,14,12,14,17,17,14,22)
③將明文數(shù)字依據(jù)密鑰長(zhǎng)度分段,并逐一與密鑰數(shù)字相加(模26),得到密文數(shù)字,即:
19 | 7 | 4 | 24 | 22 | 8 | 11 | 11 | 0 | 17 | 17 | 8 | 21 | 4 | 19 | 14 | 12 | 14 | 17 | 17 | 14 | 22 |
12 | 14 | 13 | 3 | 0 | 24 | 12 | 14 | 13 | 3 | 0 | 24 | 12 | 14 | 13 | 3 | 0 | 24 | 12 | 14 | 13 | 3 |
5 | 21 | 17 | 1 | 22 | 6 | 23 | 25 | 13 | 20 | 17 | 6 | 7 | 18 | 6 | 17 | 12 | 12 | 3 | 5 | 1 | 25 |
C=(5,21,17,1,22,6,23,25,13,20,17,6,7,18,6,17,12,12,3,5,1,25)
④依據(jù)字母和數(shù)字對(duì)應(yīng)關(guān)系將密文數(shù)字轉(zhuǎn)換為字母串,即密文為:
c=FVRBWGXZNURGHSGRMMDFBZ
主函數(shù)提供功能菜單供用戶選擇,用戶可以選擇調(diào)用以下各個(gè)功能,也可以選擇退出程序。
加密:對(duì)給定文件file1.txt內(nèi)容按照密鑰k=Monday進(jìn)行加密,加密后密文寫(xiě)到文件file2.txt中;
解密:對(duì)給定密文文件file3.txt 利用密鑰k=Monday進(jìn)行解密,解密后的明文存放在文件file4.txt中;
#include<stdio.h> int key[6]={12,14,13,3,0,24};//定義密鑰 int complex(); int simplify(); int main() { int i=0,j=0; printf("功能如下\n1.加密\n2.解密\n3.退出\n"); printf("請(qǐng)輸入您所需功能對(duì)應(yīng)的序號(hào):(例:如需調(diào)用加密功能,便打出1即可)\n"); for(;;)//直到輸入3時(shí)才會(huì)退出 { scanf("%d",&i); if(i==1)j=complex(); if(i==2)j=simplify(); if(i==3)break; if(j==1)printf("\n功能實(shí)現(xiàn)成功\n"); if(j==0)printf("\n功能實(shí)現(xiàn)失敗\n"); } return 0; } int complex() //加密 { FILE *pin, *pout; pin = fopen("file1.txt","r"); pout= fopen("file2.txt","w"); int k=0; char Ming[1000],Mi[1000],*p=Ming,*q=Mi; fgets(Ming,1000,pin); //puts(Ming); for(;*p!='\0';p++) { if(*p>='a'&&*p<='z') { *q=(*p-97+key[k])%26+65;// printf(" %d %d %c\n",*(key+k),k,*q); k=k+1;q++; if(k==6)k=0; } if(*p>='A'&&*p<='Z') { *q=(*p-65+key[k])%26+65;// printf(" %d %d %c\n",*(key+k),k,*q); k=k+1;q++; if(k==6)k=0; } } *q='\0'; //printf("密文為:"); //puts(Mi); fputs(Mi,pout); fclose(pin); fclose(pout); return 1; } int simplify()//解密 { FILE *pin, *pout; pin = fopen("file3.txt","r"); pout= fopen("file4.txt","w");//打開(kāi)文件 int k=0; //定義密鑰 //k的意義是讓密匙能夠循環(huán)使用 char Ming[1000],Mi[1000],*p=Mi,*q=Ming;//定義密文,明文字符串 fgets(Mi,1000,pin);//從文件3讀取密文 for(;*p!='\0';p++)//解密 { if(*p>='A'&&*p<='Z') { *q=(*p-65+26+26-*(key+k))%26+65;//printf(" %d %d %c\n",*(key+k),k,*q);//檢驗(yàn)key出沒(méi)出問(wèn)題 k=k+1;q++; if(k==6)k=0;//這兩行代碼讓密鑰循環(huán)使用 } } *q='\0';//使字符串結(jié)束 fputs(Ming,pout);//puts(Ming);檢驗(yàn)輸出結(jié)果//導(dǎo)出加密結(jié)果 fclose(pin); fclose(pout); //關(guān)閉兩個(gè)文件 return 1; }
到此,相信大家對(duì)“c語(yǔ)言中的文件加密與解密怎么實(shí)現(xiàn)”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。