文件加解密处理程序文件

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

程序设计报告

( 2012 /2013 学年第一学期)

题目:文件加解密处理程序

专业

学生姓名

班级学号

指导教师燕俐

指导单位计算机系统结构与网络教学中心日期 2012.12.10~12.21

一、课题容及要求

1.功能要求

编写一个对文件(由数字或字母组成)进行加密解密的程序。可以将所需要的容(整个文件或者输入的一行字符)加密,也可以将存储的加密文件翻译回来。例如加密时可以将选取容的每个字符依次反复加上”49632873”中的数字,如果围超过ASCII码值的032(空格)—122(‘z’),则进行模运算(既N%122).解密与加密的顺序相反。

2.菜单要求:

从键盘输入要进行加密的一行字符串或者需要加密的文件名。显示菜单:

1.设置加密方法

2.加密

3.解密

4.显示原始文件和解密文件

选择菜单,进行相应的操作。加密方法是设置一加密字符串以及对文件的哪些部分进行加密;加密是将原始文件加密并保存到文件中;解密是将加了密的文件还原并保存到文件中,同时应比较与原始文件的一致性;显示是将文件在屏幕上显示出来,供人工校对。

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)了解加解密的基本原理

二、需求分析

模块分析:

(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

(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 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() //加密方法设置函数

{

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 c; //临时字符存储变量

if(source == NULL )

相关文档
最新文档