资源描述:
《实验一、密码学基本算法的实现(一)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、上机实验报告(一)实验课程:应用密码学实验时间:2013年9月26日任课教师:刘光军班级:11级信息与计算科学专业1班姓名:刘静学号:0202110123一、实验名称:密码学基本算法的实现(一)二、实验目的学习常见的古典密码学算法,通过编程实现替代密码算法和置换密码算法,加深对古典密码体制的了解,为深入学习密码学奠定基础。三、实验要求1、在D盘建立一个自己的文件夹;2、开启软件平台—VisualC++6.0,在此环境下进行编程实验;3、将题目、你输入的命令、程序及运行结果保存在word文件中,作为作业提交;4、若出现错误,修改、运行直到输出正
2、确结果。四、报告正文(文档,数据,模型,程序,图形)1、编写程序实现仿射加密和Playfair密码。通过讨论分析单表代替密码和多表代替密码算法的功能需求,详细设计实现代替密码算法的数据结构和流程,给出测试用例和测试步骤,得出测试和结论。算法的实现程序必须提供加密和解密两个接口:int encrypt()和int decrypt()。当加密或者解密成功时返回CRYPT_OK,失败时返回CRYPT_ERROR。/**********加密的实现**********/#include#include#includ
3、echarbook[5][5]={''};//密码本.设为全局变量./*******************************查找在密码本中的位置。*******************************/intfindlocation(charm,int*t){9inti,j;inttemp;//表示行数.for(i=0;i<5;i++)for(j=0;j<5;j++)if(m==book[i][j]){*t=j;temp=i;i=5;//不必再循环。j=5;}returntemp;//返回行数。}/****
4、**********************密码输出函数**************************/voidout_put(ints0,intt0,ints1,intt1){charc[2]={''};if(s0==s1)//同一行。{c[0]=book[s0][(t0+1)%5];c[1]=book[s0][(t1+1)%5];}elseif(t0==t1)//同一列.{c[0]=book[(s0+1)%5][t0];c[1]=book[(s1+1)%5][t0];}else//不同行不同列.{c[0]=book[s0][t1];
5、c[1]=book[s1][t0];}printf("%c",c[0]);//输出已加密的两个字符.printf("%c",c[1]);}/*********************************对明文加密.*********************************/voidEncrypt()9{charm[2]={''};//明文数组.chartemp,ch;charflag1,flag2;//用来标志上一轮中处理的第二个字母,提高解密精度.ints0,t0,s1,t1,i;//两个字符的位置参数.temp='';//初始
6、化为空字符.i=0;//控制变量.flag1=m[1];//初始化.while((ch=getchar())!=''){if(ch=='')//如果输入的是空格跳过去.continue;if(ch=='j')//如果输入的是j则当作i处理.ch='i';m[i++]=ch;//赋入数组.if(temp!='')//如果上一步操作中有两个相同的字母.{m[1]=m[0];m[0]=temp;temp='';i=2;//标志变量,不必再输入下一个.}if(i!=2)//数组赋满,则跳过.continue;i=0;if(m[0]==m[1])/
7、/如果两个字母相同,则处理成不相同的.{temp=m[1];flag2='x';while(m[1]==m[0]
8、
9、m[1]==flag1)m[1]=flag2++;}flag1=m[1];s0=findlocation(m[0],&t0);//列值传递的是地址.s1=findlocation(m[1],&t1);m[0]='';9out_put(s0,t0,s1,t1);//在密码本中打印密码.}/*不会出现的情况是:temp!=''&&m[0]!=''*/if(temp!=''
10、
11、m[0]!='')//此处是为了防止出现什么也没有输入
12、的情况。{if(m[0]==''&&temp!='')//最后刚好剩余一位.{m[0]=temp;m[1]=flag2='x';while(m[1]==m[0]
13、
14、