1、文件加解密管理组织程序程序设计报告( 2012 /2013 学年 第 一 学期)题 目: 文件加解密处理程序 专 业 学 生 姓 名 班 级 学 号 指 导 教 师 陈燕俐 指 导 单 位 计算机系统结构与网络教学中心日 期 2012.12.1012.21 评 分 细 则评分项优秀良好中等差遵守机房规章制度上机时的表现学习态度程序准备情况程序设计能力团队合作精神课题功能实现情况算法设计合理性用户界面设计报告书写认真程度内容详实程度文字表达熟练程度回答问题准确度简 短 评 语教师签名: 年 月 日评分等级备注评分等级有五种:优秀、良好、中等、及格、不及格一、课题内容及要求1.功能要求编写一个对文
2、件(由数字或字母组成)进行加密解密的程序。可以将所需要的内容(整个文件或者输入的一行字符)加密,也可以将存储的加密文件翻译回来。例如加密时可以将选取内容的每个字符依次反复加上”49632873”中的数字,如果范围超过ASCII码值的032(空格)122(z),则进行模运算(既N%122).解密与加密的顺序相反。2.菜单要求:从键盘输入要进行加密的一行字符串或者需要加密的文件名。显示菜单:1. 设置加密方法2. 加密3. 解密4. 显示原始文件和解密文件选择菜单,进行相应的操作。加密方法是设置一加密字符串以及对文件的哪些部分进行加密;加密是将原始文件加密并保存到文件中;解密是将加了密的文件还原并
3、保存到文件中,同时应比较与原始文件的一致性;显示是将文件在屏幕上显示出来,供人工校对。3. 程序设计参考思路:(1)定义原始文件sourse.txt、加密文件result.txt和还原文件recall.txt(2) 程序模块及函数功能:(1) 在屏幕上显示文件 void printtxt();(2) 加密void encode();(3) 解密void decode();(4) 文件比较void cmptxt();4.需要的知识:(1)文件读取写入操作语言(2)字符串的处理,如何对字符进行加减操作,并保证加减后的数值处于某一范围之内 (模运算) (3) 了解加解密的基本原理二、需求分析模块分析
4、:(1)在屏幕上显示文件 void printtxt() 用于将原始文件sourse.txt,加密文件result.txt,解密文件recall.txt,的内容显示在屏幕上,方便检验程序是否正确执行。在此函数中要以输入方式打开三个文件。(2)加密void encode() 对原始文件sourse.txt整个或部分字符串加密,并将加密后的内容写入result.txt上。加密时,每个字符依次反复加上”4963287312”中的数字,如果范围超过ASCII码值的032(空格)122(z),则进行模运算(即N%122). 例如:加密the(t)116+4,(h)104+9,(e)101+6 变为xqk
5、(3)解密void decode() 对加密后的result.txt进行解密,并将解密后的内容写入recall.txt文件中。解密过程与加密过程的顺序正好相反,即从第一个字符开始,每个字符依次反复减去”4963287312”中的数字,若执行减法后得到一个负数,则把这个负数加122,即 (N+122), 其中N为负数。 例如:把xqk解密 (x) 120-4 (q)111-9 (k) 107-6 变为 the(4)设置加密方法void set() 由键盘输入,得到加密字节数和加密字符串,进行加密方法的设置,主要由输出输入语句组成,目的是为了方便人机交流。(5)加密方法用结构表示struct pa
6、ssword /*加密方法*/ char ps10; /*加密字符串*/long wd; /*加密的字节数*/;(6)文件比较void cmptxt() 从source文件和recall文件中读取字符并进行比较,看加解密是否成功。但由于已经在屏幕上显示原文件和解密文件,故不调用。(7)显示菜单:* 1.设置加密方法 * 2.加密 * 3.解密 * 4.显示文件 * 5.退出 *三、概要设计 1.加密程序的设计:开始,以输出方式打开加密文件,以输入方式打开原始文件,判断文件是否为空,若为空,对字符串进行加密:定义for循环,判断i值是否小于字符串的长度,是则进行加密运算,即将字符所对应的ASCA
7、LL码加上加密字符串所对应的数字减去48,得到的就是加密后的字符,如果范围超过ASCII码值的032(空格)122(z),则进行模运算(即N%122),将加密后的文字写入加密文件,关闭打开的两个文件,屏幕显示加密成功。如果文件不为空,则对文件中字符加密,加密过程与上述加密过程相似。2.解密程序的设计:开始,以输出方式打开解密密文件,以输入方式打开加密文件,对加密后的文件中的字符串进行解密:定义for循环,判断i值是否小于字符串的长度,是则进行加密运算,即将字符所对应的ASCALL码减去加密字符串所对应的数字加上48,得到的就是解密后的字符,若执行减法后得到一个负数,则把这个负数加122,即 (
8、N+122), 其中N为负数。将解密后的文字写入解密文件,关闭打开的两个文件,屏幕显示解密成功。3.显示程序的设计:以输入方式打开原始文件,加密文件,解密文件,将文件中进行的字符串读入到屏幕上,方便读者进行比较。4.主函数的设计:选用switch语句,从键盘读入字符以选择调用函数,实现操作。四、源程序#include#include#include struct password /*加密方法结构变量*/ char ps10; /*密字符串*/ long wd; /*加密的字节数*/; struct password password; char s100; void set() /加密方法设
9、置函数 printf(n输入加密字符串:); scanf(%s,password.ps); printf(n输入加密字节数:); scanf(%ld,&password.wd); getchar(); system(pause); /*系统函数,按任意键继续,使界面整洁*/void Printtxt() /*显示显示原始文件和解密文件函数*/ /*以读方式打开文件*/ FILE *source = fopen(source.txt,rt); FILE *result = fopen(result.txt,r); FILE *recall = fopen(recall.txt,rt); char
10、 c; /临时字符存储变量 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); /先从原始文件读出一个字符,若不是文件结尾,则文件内容非空 if(c =EOF) /文件内容为空,输出加密字符 printf(n加密字符:); printf(%sn,s); else /文件非空,输出原始
11、文件 printf(n原始文件:); printf(%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); f
12、close(recall); system(pause); void encode() /*加密函数*/ 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
13、 ) printf(无法打开 source.txt n); flag = 0; if (flag = 1) C = fgetc(source); /得到一个文件内容 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); e
14、lse /文件非空,对文件加密 w=C+password.ps0%n-48; 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() /*解密函数*/ FILE * recall = fopen(recall.txt,wt)
15、; FILE * result = fopen(result.txt,rt); 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+) /对加密文件进行译码 static int a=0; if(apassword.wd) N=c-(passw
16、ord.psa%n-48); if(N0) N=(N+122)%122; /*模运算*/ fputc(N,recall); else if(N=0) fputc(z,recall); /将解密结果输出至recall文件 else fputc(N,recall); a+; else fputc(c,recall) ; printf(n解密成功!n); fclose(result); fclose(recall); system(pause);void cmptxt() /*比较解密文件和原始文件的一致性,一致输出原字符,不一致输出_*/ /在程序中没有调用 FILE *source = fope
17、n(sourse.txt,rt); FILE *recall = fopen(recall.txt,rt); char c,d; /临时字符存储变量 if(source = NULL ) printf(不存在 source.txt 文件n); exit(0); if(recall = NULL ) printf(不存在 recall.txt 文件n); exit(0); /先从原始文件读出一个字符,若不是文件结尾,则文件内容非空 c = fgetc(source); d = fgetc(recall); if(c =EOF) printf(读文件错误!n); exit(0); if(d =EO
18、F) printf(读文件错误!n); exit(0); printf(文件比较:); if(c = d) printf(%c,c); else printf(_); while(c=fgetc(source) != EOF & (c=fgetc(source) != EOF) /文件非空调用判断 if(c = d) /比较,输出字符 printf(%c,c); else printf(_); printf(n); fclose(source); fclose(recall); system(pause); void menu() /菜单函数 printf(n*文件加解密*); printf(
19、n*n); printf(* 1.设置加密方法 * 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() /创建文件 FILE *f1 = fopen(source.txt,wt); FILE *f2 = fopen(result.txt,wt); FILE *f3 = fop
20、en(recall.txt,wt); fclose(f1); fclose(f2); fclose(f3); void main() /主函数,进行选择 int a=0; menu(); while (a!=5) scanf(%d,&a); switch(a) case 1: creat(); set(); system(cls); menu(); break; case 2: encode(); system(cls); menu(); break; case 3: decode(); system(cls); menu(); break; case 4: Printtxt(); syste
21、m(cls); menu(); break; case 5: printf(n 结束 !nn); break; default: printf(n 请再次输入! n); system(cls); menu(); break; 五、测试数据及其结果分析选择1设置加密方法,加密字符串496,为前五位字符加密从键盘读入要加密的字符串文件并加密解密显示加密文件与解密文件七、课程设计总结遇到的问题:1,在解密文件时会遇到将未被加密的字符进行解密,以致出现错误的解密文件。后来发现解密函数中有一句的文件字符写入写错了,从result文件中读出即可解决。2,程序不能给长文件加密,后来计算需加密文件长度,对加密字符串长度取余,即可实现重复的加密,实现全文加密。感想:虽然老师什么都不讲,但是自己动手查资料,讨论语句的功能还是很有意思的,也更加巩固了c语言知识,能灵活的运用知识了。
copyright@ 2008-2023 冰点文库 网站版权所有
经营许可证编号:鄂ICP备19020893号-2