密码实验报告2(6700字)

发表于:2018.1.10来自:www.ttfanwen.com字数:6700 手机看范文

一、实验目的

实验为验证性实验。

通过本实验,使学生对于两种基本的古典密码编码方法(“代替”与“移位”) 产生深刻的感性认识,体验清楚二者之间的本质差异,为理解和掌握现代密码的相应知识打下良好基础。

二、实验内容

1. 设计一个周期 3 的多表代替密码并予以实现,要求:第 1 个表由密钥字法 产生(密钥字自拟),第 2 个表由洗牌法产生(注意,字母 a~z 与数字 0~25 一一对应,洗牌法即相当于实验一的方法 1(n=25)),第三个表由公式法 产生(数学公式自拟,注意它须是 Z26 上的一个一一变换)。

2. 设计一个周期 5 的 16-置换移位密码并予以实现,要求:5 个 16-置换至少 有一个是由实验一(n=15)提供的两个方法以外、自行设计的其它方法产 生。

三、实验要求

1. 上述两个古典密码的编程实现,须能对下面一段明文进行正确加密(对代 替密码,空格和标点符号保持不动;对移位密码,空格和标点符号也移位): Q is a symmetric block cipher. It is defined for a block size of 128 bits. It allows arbitrary length passwords. The design is fairly conservative. It consists of a simple substitution-permutation network. In this paper we present the cipher, its design criteria and our analysis. The design is based on both Rjindael and Serpent. It uses an 8-bit s-box from Rjindael with the linear mixing layers replaced with two Serpent style bit-slice s-boxes and a linear

permutation. The combination of methods eliminates the high level structure inherent in Rjindael while having better speed and avalanche characteristics than Serpent. Speed is improved over Serpent. This version 2.00 contains better analysis, editorial changes, and an improved key scheduling algorithm. The number of recommended rounds is also increased.

2. 抓图显示密文(附页),不能出现明显错误。

四、实验步骤

1.通过预习和老师在实验课上的讲解,理解代替密码和移位密码的本质差别,对程序的作用有初步了解;

2.分析实验指导书上所列代码,搞清楚各个子函数的功能、理清程序的大体思路;

3.将主函数与各个子函数进行合并整合,处理编译上出现的语法问题,使编译可以顺利通过;

4.完善程序,输入数据对程序的逻辑功能进行验证,测试随机数结构调用是否完整,测试结果是否符合对应的加密要求,验证打开关闭文件是否顺利。

1

五、实验体会

六、思考题

“代替表”与“置换”的不动点、逆等是否一致?

答: 不一致。代替是约定明文集合到另一集合的关系,不一定是原来的集合,而移位是在 明文集合中进行随机排列然后得到的密文。两者的不动点、逆等只有在统一集合变换时 才可能一致。

七、实验代码及运行结果

实验代码:

1. 代替密码

#include<stdio.h>

#include<time.h>

#include<string.h>

#include<ctype.h>

#include<stdlib.h>

/*声明子函数*/

unsigned char *full_array2(char n); /*fully_array函数产生随机数*/ int letter_to_digit(char c);

char digit_to_letter(int n);

unsigned char *KeyGen_s( );

void Encrypt_s(unsigned char *key);

/*主函数*/

int main()

{

printf("---------代替密码加密算法---------\n");

Encrypt_s(KeyGen_s());

system("pause");

return 0;

}

unsigned char *full_array2(char n) /*fully_array函数产生随机数*/ {

int m,i,j,k,l =0,flag;

static unsigned char P[256];

start:

printf("\n请输入不小于%d的所有随机数个数:\n",n+1);

scanf("%d",&m);

if(m<=n)

2

{

printf("\n输入数%d比%d小,须重新输入!\n",m,n+1);

goto start;

}

srand((unsigned)time(NULL));/*初始化随机种子*/

for(i=0;i<m;i++)

{

P[l++]=(unsigned char)(rand()%(n+1));

for(j=0;j<l-1;j++)

{

if(P[j]==P[l-1])

{

l--;

break;

}

}

}

k=l;

for(i=0;i<=n;i++)

{

flag=0;

for(j=0;j<k;j++)

if(P[j]==i)

{

flag=l;

break;

}

if(!flag)

{

P[l]=i;

l++;

}

}

return(P);

}

int letter_to_digit(char c)

{

int i;

char alphabet[27]={"abcdefghijklmnopqrstuvwxyz"}; for(i=0;i<26;i++) if(tolower(c)==alphabet[i]) return(i);

return(-1);

}

char digit_to_letter(int n)

{

3

char alphabet[27]={"abcdefghijklmnopqrstuvwxyz"}; if(n<0||n>25) return(0);

return(alphabet[n]);

}

unsigned char *KeyGen_s( )

{

char KeyWords[106];

char ChoiceWords[26];

unsigned char *p;

static unsigned char KeyTab[26*3];

int i,j,k,l;

printf("\n 请输入密钥字:\n");

gets(KeyWords);

strcat(KeyWords,"abcdefghijklmnopqrstuvwxyz"); k=0;

l=strlen(KeyWords);

ChoiceWords[k]=tolower(KeyWords[0]);

for(i=1;i<l;i++)

{

if(letter_to_digit(KeyWords[i])==-1) continue;

ChoiceWords[++k]=tolower(KeyWords[i]); for(j=0;j<k;j++)

if(ChoiceWords[j]==ChoiceWords[k])

{

k--;

break;

}

}

for(i=0;i<26;i++)

KeyTab[i]=(unsigned char)letter_to_digit(ChoiceWords[i]); p=full_array2(25);

for(i=0;i<26;i++)

KeyTab[26+i]=p[i];

for(i=0;i<26;i++)

KeyTab[52+i]=(unsigned char)((7*i+3)%26);

return(KeyTab);

}

void Encrypt_s(unsigned char *key)

{

int i;

FILE *fp;

char filename[20],c;

start:

printf("\n 请输入待加密文本文件名:\n");

4

scanf("%s",filename);

if( (fp=fopen(filename,"rt"))==NULL )

{

printf("没有找到文件:%s\n",filename);

goto start;

}

printf("\n 密文如下:\n");

i=0;

while((c=fgetc(fp))!=EOF)

{

if(letter_to_digit(c)==-1)

{

putchar(c);

continue;

}

//公式选为 7*i+3(mod 26)

isupper(c)?

putchar(toupper(digit_to_letter(key[(int)((i/26)*26+letter_to_digit(c))]))): \

putchar(digit_to_letter(key[(int)((i/26)*26+letter_to_digit(c))])); i++;

if(i>=26*3) i=0;

}

fclose(fp);

}

2. 移位密码

#include<stdio.h>

#include<time.h>

#include<string.h>

#include<ctype.h>

#include<stdlib.h>

/*声明子函数*/

unsigned char *full_array2(char n);

int letter_to_digit(char c) ;

char digit_to_letter(char n) ;

unsigned char *KeyGen_p( ) ;

void Encrypt_p(unsigned char *key) ;

5

/*主函数*/

int main()

{

printf("---------移位密码加密算法---------\n");

Encrypt_p(KeyGen_p());

system("pause");

return 0;

}

unsigned char *full_array2(char n) /*fully_array函数产生随机数*/ {

int m,i,j,k,l =0,flag;

static unsigned char P[256];

start:

printf("\n请输入不小于%d的所有随机数个数:(周期为5)\n",n+1); scanf("%d",&m);

if(m<=n)

{

printf("\n输入数%d比%d小,须重新输入!\n",m,n+1);

goto start;

}

srand((unsigned)time(NULL));/*初始化随机种子*/

for(i=0;i<m;i++)

{

P[l++]=(unsigned char)(rand()%(n+1));

for(j=0;j<l-1;j++)

{

if(P[j]==P[l-1])

{

l--;

break;

}

}

}

k=l;

for(i=0;i<=n;i++)

{

flag=0;

for(j=0;j<k;j++)

if(P[j]==i)

{

flag=l;

break;

}

if(!flag)

6

{

P[l]=i;

l++;

}

}

return(P);

}

int letter_to_digit(char c) /*将字母转化为数字*/

{

int i;

char alphabet[27]={"abcdefghijklmnopqrstuvwxyz"}; for(i=0;i<26;i++) if(tolower(c)==alphabet[i]) return(i);

return(-1);

}

char digit_to_letter(char n)/*将数字转化为字母*/

{

char alphabet[27]={"abcdefghijklmnopqrstuvwxyz"};

if(n<0||n>25) return(0);

return(alphabet[n]);

}

unsigned char *KeyGen_p( )/*产生密钥*/

{

unsigned char *p;

static unsigned char KeyTab[16*5];

int i,j;

for(i=0;i<5;i++)

{

p=full_array2(15);

for(j=0;j<16;j++)

KeyTab[16*i+j]=p[j];

}

return(KeyTab);

}

void Encrypt_p(unsigned char *key) /*实现明文加密*/

{

int i,j;

FILE *fp;

char filename[20],c;

char d[16];

start:

printf("\n 请输入待加密文本文件名:\n");

scanf("%s",filename);

if( (fp=fopen(filename,"rt"))==NULL )

7

{

printf("没有找到文件:%s\n",filename); goto start; }

printf("\n 密文如下:\n");

i=0;

while((c=fgetc(fp))!=EOF)

{

d[i%16]=c;

i++;

if(i%16!=0) continue;

for(j=0;j<16;j++)

putchar(d[key[(int)(((i-1)/16)*16+j)]]); if(i>=16*5) i=0; }

if(i%16!=0)

{

for(j=i%16;j<16;j++)d[j]='*';

for(j=0;j<16;j++)

putchar(d[key[(int)((i/16)*16+j)]]);

}

putchar('\n');

fclose(fp);

}

附录:运行结果截图

密码实验报告2

8

密码实验报告2

密码实验报告2

9




第二篇:密码学实验报告二(附图)

《现代密码学》实验报告

密码学实验报告二

报告创建时间:

密码学实验报告二

密码学实验报告二

密码学实验报告二

密码学实验报告二

更多类似范文
┣ 更多密码学实验报告
┗ 搜索类似范文

更多相关推荐:
单片机课程设计报告--电子密码锁3900字

电子密码锁一课题概述在日常生活和工作中住宅与部门的安全防范单位的文件档案财务报表以及一些个人资料的保存多以加锁的办法来解决若使用机械式钥匙开锁人们常需携带多把钥匙使用极不方便且钥匙丢失后安在日常生活和工作中住宅...

实验报告.2密码破解实验500字

电子证据实验报告实验二指导教师学院班级学号姓名考号实验日期小组成员实验一密码破解实验一实验目的1学会用Archpr软件对压缩文件简单密码的破解2学会用aopr软件对文件密码的破解二实验内容1用Archpr软件对...

电子密码锁课程设计报告4400字

电子密码锁一引言随着人们生活水平的提高人们对自己的生活有了越来越高的要求贵重物品也越来越多而传统的机械安全锁由于其构造的简单被撬被盗事件在我们身边经常发生使我们的财产以及人身安全存在很大的安全隐患这致使我们寻求...

专栏推荐
大家在关注

地图地图CC