文件加解密处理程序-CAL-FENGHAI-(2020YEAR-YICAI)_JINGBIAN
程序设计报告
( 2012 /2013 学年第一学期)
题目:文件加解密处理程序
专业
学生姓名
班级学号
指导教师陈燕俐
指导单位计算机系统结构与网络教学中心
日期
评评分项优秀良好中等差
一、课题内容及要求
1.功能要求
编写一个对文件(由数字或字母组成)进行加密解密的程序。
可以将所需要的内容(整个文件或者输入的一行字符)加密,也可以将存储的加密文件翻译回来。
例如加密时可以将选取内容的每个字符依次反复加上”49632873”中的数字,如果范围超过ASCII码值的032(空格)—122(‘z’),则进行模运算(既N%122).解密与加密的顺序相反。
2.菜单要求:
从键盘输入要进行加密的一行字符串或者需要加密的文件名。
显示菜单:
1.设置加密方法
2.加密
3.解密
4.显示原始文件和解密文件
选择菜单,进行相应的操作。
加密方法是设置一加密字符串以及对文件的哪些部分进行加密;加密是将原始文件加密并保存到文件中;解密是将加了密的文件还原并保存到文件中,同时应比较与原始文件的一致性;显示是将文件在屏幕上显示出来,供人工校对。
3. 程序设计参考思路:
(1)定义原始文件、加密文件和还原文件
(2) 程序模块及函数功能:
(1)在屏幕上显示文件 void printtxt();
(2)加密void encode();
(3)解密void decode();
(4)文件比较void cmptxt();
4.需要的知识:
(1)文件读取写入操作语言
(2)字符串的处理,如何对字符进行加减操作,并保证加减后的数值处于某一范围之内(模运算)
(3)了解加解密的基本原理
二、需求分析
模块分析:
(1)在屏幕上显示文件 void printtxt()
用于将原始文件,加密文件,解密文件,的内容显示在屏幕上,方便检验程序是否正确执行。
在此函数中要以输入方式打开三个文件。
(2)加密void encode()
对原始文件整个或部分字符串加密,并将加密后的内容写入上。
加密时,每个字符依次反复加上”4963287312”中的数字,如果范围超过ASCII码值的032(空格)—122(‘z’),则进行模运算(即N%122).
例如:加密the
(t)116+4,(h)104+9,(e)101+6
变为xqk
(3)解密void decode()
对加密后的进行解密,并将解密后的内容写入文件中。
解密过程与加密过程的顺序正好相反,即从第一个字符开始,每个字符依次反复减去”4963287312”中的数字,若执行减法后得到一个负数,则把这个负数加122,即 (N+122), 其中N为负数。
例如:把xqk解密
(x) 120-4 (q)111-9 (k) 107-6
变为 the
(4)设置加密方法void set()
由键盘输入,得到加密字节数和加密字符串,进行加密方法的设置,主要由输出输入语句组成,目的是为了方便人机交流。
(5)加密方法用结构表示
struct password /*加密方法*/
{
char ps[10]; /*加密字符串*/
long wd; /*加密的字节数*/
};
(6)文件比较void cmptxt()
从source文件和recall文件中读取字符并进行比较,看加解密是否成功。
但由于已经在屏幕上显示原文件和解密文件,故不调用。
(7)显示菜单:
******************
* 1.设置加密方法 *
* 2.加密 *
* 3.解密 *
* 4.显示文件 *
* 5.退出 *
******************
三、概要设计
1.加密程序的设计:
开始,以输出方式打开加密文件,以输入方式打开原始文件,判断文件是否为空,若为空,对字符串进行加密:定义for循环,判断i值是否小于字符串的长度,是则进行加密运算,即将字符所对应的ASCALL码加上加密字符串所对应的数字减去48,得到的就是加密后的字符,如果范围超过ASCII码值的032(空格)—122(‘z’),则进行模运算(即
N%122),将加密后的文字写入加密文件,关闭打开的两个文件,屏幕显示加密成功。
如果文件不为空,则对文件中字符加密,加密过程与上述加密过程相似。
2.解密程序的设计:
开始,以输出方式打开解密密文件,以输入方式打开加密文件,对加密后的文件中的字符串进行解密:定义for循环,判断i值是否小于字符串的长度,是则进行加密运算,即将字符所对应的ASCALL码减去加密字符串所对应的数字加上48,得到的就是解密后的字符,若执行减法后得到一个负数,则把这个负数加122,即 (N+122), 其中N为负数。
将解密后的文字写入解密文件,关闭打开的两个文件,屏幕显示解密成功。
3.显示程序的设计:
以输入方式打开原始文件,加密文件,解密文件,将文件中进行的字符串读入到屏幕上,方便读者进行比较。
4.主函数的设计:
选用switch语句,从键盘读入字符以选择调用函数,实现操作。
四、源程序
#include<>
#include<>
#include <>
struct password /*加密方法结构变量*/
{
char ps[10]; /*密字符串*/
long wd; /*加密的字节数*/
};
struct password password;
char s[100];
void set() 置加密方法 * \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("","wt");
FILE *f2 = fopen("","wt");
FILE *f3 = fopen("","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();
system("cls");
menu();
break;
case 5:
printf("\n 结束 !\n\n");
break;
default:
printf("\n 请再次输入! \n");
system("cls");
menu();
break;
}
}
}
五、测试数据及其结果分析
选择1设置加密方法,加密字符串496,为前五位字符加密
从键盘读入要加密的字符串文件并加密
解密
显示加密文件与解密文件
七、课程设计总结
遇到的问题:
1,在解密文件时会遇到将未被加密的字符进行解密,以致出现错误的解密文件。
后来发现解密函数中有一句的文件字符写入写错了,从result文件中读出即可解决。
2,程序不能给长文件加密,后来计算需加密文件长度,对加密字符串长度取余,即可实现重复的加密,实现全文加密。
感想:
虽然老师什么都不讲,但是自己动手查资料,讨论语句的功能还是很有意思的,也更加巩固了c语言知识,能灵活的运用知识了。