文件加解密處理程序_第1頁
文件加解密處理程序_第2頁
文件加解密處理程序_第3頁
文件加解密處理程序_第4頁
文件加解密處理程序_第5頁
已閱讀5頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、程序設(shè)計報告( 2012 /2013 學(xué)年 第 一 學(xué)期)題 目: 文件加解密處理程序 專 業(yè) 學(xué) 生 姓 名 班 級 學(xué) 號 指 導(dǎo) 教 師 陳燕俐 指 導(dǎo) 單 位 計算機(jī)系統(tǒng)結(jié)構(gòu)與網(wǎng)絡(luò)教學(xué)中心日 期 2012.12.1012.21 評 分 細(xì) 則評分項優(yōu)秀良好中等差遵守機(jī)房規(guī)章制度上機(jī)時的表現(xiàn)學(xué)習(xí)態(tài)度程序準(zhǔn)備情況程序設(shè)計能力團(tuán)隊合作精神課題功能實現(xiàn)情況算法設(shè)計合理性用戶界面設(shè)計報告書寫認(rèn)真程度內(nèi)容詳實程度文字表達(dá)熟練程度回答問題準(zhǔn)確度簡 短 評 語教師簽名: 年 月 日評分等級備注評分等級有五種:優(yōu)秀、良好、中等、及格、不及格一、課題內(nèi)容及要求1.功能要求編寫一個對文件(由數(shù)字或字母組成)

2、進(jìn)行加密解密的程序??梢詫⑺枰膬?nèi)容(整個文件或者輸入的一行字符)加密,也可以將存儲的加密文件翻譯回來。例如加密時可以將選取內(nèi)容的每個字符依次反復(fù)加上”49632873”中的數(shù)字,如果范圍超過ASCII碼值的032(空格)122(z),則進(jìn)行模運算(既N%122).解密與加密的順序相反。2.菜單要求:從鍵盤輸入要進(jìn)行加密的一行字符串或者需要加密的文件名。顯示菜單:1. 設(shè)置加密方法2. 加密3. 解密4. 顯示原始文件和解密文件選擇菜單,進(jìn)行相應(yīng)的操作。加密方法是設(shè)置一加密字符串以及對文件的哪些部分進(jìn)行加密;加密是將原始文件加密并保存到文件中;解密是將加了密的文件還原并保存到文件中,同時應(yīng)比

3、較與原始文件的一致性;顯示是將文件在屏幕上顯示出來,供人工校對。3. 程序設(shè)計參考思路:(1)定義原始文件sourse.txt、加密文件result.txt和還原文件recall.txt(2) 程序模塊及函數(shù)功能:(1) 在屏幕上顯示文件 void printtxt();(2) 加密void encode();(3) 解密void decode();(4) 文件比較void cmptxt();4.需要的知識:(1)文件讀取寫入操作語言(2)字符串的處理,如何對字符進(jìn)行加減操作,并保證加減后的數(shù)值處于某一范圍之內(nèi) (模運算) (3) 了解加解密的基本原理二、需求分析模塊分析:(1) 在屏幕上顯示

4、文件 void printtxt() 用于將原始文件sourse.txt,加密文件result.txt,解密文件recall.txt,的內(nèi)容顯示在屏幕上,方便檢驗程序是否正確執(zhí)行。在此函數(shù)中要以輸入方式打開三個文件。(2) 加密void encode() 對原始文件sourse.txt整個或部分字符串加密,并將加密后的內(nèi)容寫入result.txt上。加密時,每個字符依次反復(fù)加上”4963287312”中的數(shù)字,如果范圍超過ASCII碼值的032(空格)122(z),則進(jìn)行模運算(即N%122). 例如:加密the(t)116+4,(h)104+9,(e)101+6 變?yōu)閤qk(3) 解密voi

5、d decode() 對加密后的result.txt進(jìn)行解密,并將解密后的內(nèi)容寫入recall.txt文件中。解密過程與加密過程的順序正好相反,即從第一個字符開始,每個字符依次反復(fù)減去”4963287312”中的數(shù)字,若執(zhí)行減法后得到一個負(fù)數(shù),則把這個負(fù)數(shù)加122,即 (N+122), 其中N為負(fù)數(shù)。 例如:把xqk解密 (x) 120-4 (q)111-9 (k) 107-6 變?yōu)?the(4) 設(shè)置加密方法void set() 由鍵盤輸入,得到加密字節(jié)數(shù)和加密字符串,進(jìn)行加密方法的設(shè)置,主要由輸出輸入語句組成,目的是為了方便人機(jī)交流。(5)加密方法用結(jié)構(gòu)表示struct password

6、/*加密方法*/ char ps10; /*加密字符串*/long wd;/*加密的字節(jié)數(shù)*/;(6)文件比較void cmptxt() 從source文件和recall文件中讀取字符并進(jìn)行比較,看加解密是否成功。但由于已經(jīng)在屏幕上顯示原文件和解密文件,故不調(diào)用。(7)顯示菜單:* 1.設(shè)置加密方法 * 2.加密 * 3.解密 * 4.顯示文件 * 5.退出 *三、概要設(shè)計 1.加密程序的設(shè)計:開始,以輸出方式打開加密文件,以輸入方式打開原始文件,判斷文件是否為空,若為空,對字符串進(jìn)行加密:定義for循環(huán),判斷i值是否小于字符串的長度,是則進(jìn)行加密運算,即將字符所對應(yīng)的ASCALL碼加上加密字

7、符串所對應(yīng)的數(shù)字減去48,得到的就是加密后的字符,如果范圍超過ASCII碼值的032(空格)122(z),則進(jìn)行模運算(即N%122),將加密后的文字寫入加密文件,關(guān)閉打開的兩個文件,屏幕顯示加密成功。如果文件不為空,則對文件中字符加密,加密過程與上述加密過程相似。2.解密程序的設(shè)計:開始,以輸出方式打開解密密文件,以輸入方式打開加密文件,對加密后的文件中的字符串進(jìn)行解密:定義for循環(huán),判斷i值是否小于字符串的長度,是則進(jìn)行加密運算,即將字符所對應(yīng)的ASCALL碼減去加密字符串所對應(yīng)的數(shù)字加上48,得到的就是解密后的字符,若執(zhí)行減法后得到一個負(fù)數(shù),則把這個負(fù)數(shù)加122,即 (N+122),

8、其中N為負(fù)數(shù)。將解密后的文字寫入解密文件,關(guān)閉打開的兩個文件,屏幕顯示解密成功。3.顯示程序的設(shè)計:以輸入方式打開原始文件,加密文件,解密文件,將文件中進(jìn)行的字符串讀入到屏幕上,方便讀者進(jìn)行比較。4.主函數(shù)的設(shè)計:選用switch語句,從鍵盤讀入字符以選擇調(diào)用函數(shù),實現(xiàn)操作。四、源程序#include#include#include struct password /*加密方法結(jié)構(gòu)變量*/ char ps10; /*密字符串*/long wd; /*加密的字節(jié)數(shù)*/; struct password password; char s100; void set() /加密方法設(shè)置函數(shù) print

9、f(n輸入加密字符串:); scanf(%s,password.ps); printf(n輸入加密字節(jié)數(shù):); scanf(%ld,&password.wd); getchar();system(pause); /*系統(tǒng)函數(shù),按任意鍵繼續(xù),使界面整潔*/void Printtxt() /*顯示顯示原始文件和解密文件函數(shù)*/ /*以讀方式打開文件*/FILE *source = fopen(source.txt,rt); FILE *result = fopen(result.txt,r);FILE *recall = fopen(recall.txt,rt); char c; /臨時字符存儲變

10、量if(source = NULL ) printf(無法打開 source.txt n);exit(0);if(result = NULL ) printf(無法打開 result.txt n);exit(0);if(recall = NULL ) printf(無法打開 recall.txt n);exit(0);c = fgetc(source); /先從原始文件讀出一個字符,若不是文件結(jié)尾,則文件內(nèi)容非空if(c =EOF) /文件內(nèi)容為空,輸出加密字符 printf(n加密字符:);printf(%sn,s); else /文件非空,輸出原始文件 printf(n原始文件:); pr

11、intf(%c,c);while(c=fgetc(source) != EOF) printf(%c,c); printf(n);printf(n加密文件:);while(c=fgetc(result) != EOF) /文件非空,輸出加密文件printf(%c,c); printf(n);printf(n);printf(n解密文件:);while(c=fgetc(recall) != EOF) /文件非空,輸出解密文件printf(%c,c); printf(n);fclose(source); fclose(result); fclose(recall); system(pause);

12、void encode() /*加密函數(shù)*/ int m,n=strlen(password.ps),i,flag = 1; /m存儲加密字符長度 ,n存儲加密字符串長度 ,i 為臨時變量char N,w; char c,C; /臨時字符存儲變量FILE *result = fopen(result.txt,wt); FILE *source = fopen(source.txt,wt); if(result = NULL ) printf(無法打開 result.txt n);exit(0); if(source = NULL ) printf(無法打開 source.txt n);flag

13、 = 0;if (flag = 1) C = fgetc(source); /得到一個文件內(nèi)容if(flag = 0 | C=EOF ) /判斷文件是否為空,為空的話,對輸入字符加密 printf(請輸入要加密的字符串:n); scanf(%s,s);m=strlen(s); fprintf(source,%s,s); for(i=0;im;i+) static int a=0; if(a122) N=N%122; /*模運算*/ fputc(N,result); a+;else fputc(si,result); else /文件非空,對文件加密 w=C+password.ps0%n-48;

14、fputc(w,result); for( i=0;(c=fgetc(source) != EOF;i+) static int a=1; if(a122) N=N%122; /*模運算*/ fputc(N,result); a+; else fputc(N,result); printf(n加密成功!n); fclose(result); fclose(source);system(pause);void decode() /*解密函數(shù)*/ FILE * recall = fopen(recall.txt,wt); FILE * result = fopen(result.txt,rt);

15、char c,N; int n=strlen(password.ps), i; /n存儲加密字符串長度,i為臨時變量if(result = NULL ) printf(無法打開 result.txt n);exit(0); if(recall = NULL ) printf(無法打開 result.txt n);exit(0); for( i=0;(c=fgetc(result) != EOF;i+) /對加密文件進(jìn)行譯碼 static int a=0; if(apassword.wd) N=c-(password.psa%n-48); if(N0) N=(N+122)%122; /*模運算*

16、/fputc(N,recall); else if(N=0) fputc(z,recall); /將解密結(jié)果輸出至recall文件else fputc(N,recall); a+; else fputc(c,recall) ; printf(n解密成功!n); fclose(result); fclose(recall);system(pause);void cmptxt() /*比較解密文件和原始文件的一致性,一致輸出原字符,不一致輸出_*/ /在程序中沒有調(diào)用 FILE *source = fopen(sourse.txt,rt); FILE *recall = fopen(recall.

17、txt,rt); char c,d; /臨時字符存儲變量 if(source = NULL ) printf(不存在 source.txt 文件n); exit(0); if(recall = NULL ) printf(不存在 recall.txt 文件n); exit(0); /先從原始文件讀出一個字符,若不是文件結(jié)尾,則文件內(nèi)容非空 c = fgetc(source); d = fgetc(recall); if(c =EOF) printf(讀文件錯誤!n); exit(0); if(d =EOF) printf(讀文件錯誤!n); exit(0); printf(文件比較:); if

18、(c = d) printf(%c,c); else printf(_); while(c=fgetc(source) != EOF & (c=fgetc(source) != EOF) /文件非空調(diào)用判斷 if(c = d) /比較,輸出字符 printf(%c,c); else printf(_); printf(n); fclose(source); fclose(recall); system(pause); void menu() /菜單函數(shù) printf(n*文件加解密*);printf(n*n);printf(* 1.設(shè)置加密方法 * n);printf( n);printf(* 2.加密文件 * n);printf( n);printf(* 3.解密文件 * n);printf( n);printf(* 4.顯示文件 * n);printf( n);printf(* 5.退出 * n);printf( n);printf(*n);printf(請選擇:);void creat() /創(chuàng)建文件FILE *f1 = fopen(source.txt,wt); FILE *f2 = fopen(result.txt,wt); FILE *f3 = fopen(recall.txt,wt); fclose(f1); fclose(f2);fclose

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論