欢迎来到天天文库
浏览记录
ID:5264221
大小:217.91 KB
页数:6页
时间:2017-12-07
《维吉尼亚实验报告》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、维吉尼亚密实现与攻击一、实验目的:维吉尼亚密码是古典密码中非常具有代表的例子。本实验要求用高级语言编写和调试一个简单的维吉尼亚密码实现及分析破译程序。通过本实验可以加深理解维吉尼亚密码及其分析破译。二、实验要求:(1)从数据文件data.txt(result.txt)中读入要加(解)密的数据,将加(解)密结果再写入文件result_v.txt(data.txt)中。统计密文数据中明文字母和加密后得到的密文字母的频率,并找出各自频率最大的5个字母;由相关数据计算密文的密表数。(2)为维吉尼亚密码算法编写独立的模块(通过头文件调用),在主程序中调用相应的函数。(3)维吉尼亚密钥字:hel
2、lo。(4)明文中空格、标点符号等均忽略。三、实验步骤:(1)了解维吉尼亚加密原理维吉尼亚使用一个词组作为密钥,密钥中每一个字母用来确定一个代替表,每一个密钥字母被用来加密一个明文字母,等所有密钥字母使用完后,密钥再循环使用。维吉尼亚是最著名的多表代替密码的例子。例如用Vigenere加密“wananyu”K=songhua步骤如下:1.对照字母表写出“wananyu”在字母表中的位置,以及明文“songhua”所对应的密钥字母在字母表中的位置,如下:wanaNyu220130132420songHua181413672002.维基利亚密码加密函数为:f(Pi)=(Pi+Ki)mod
3、26,f(Pi)表示密文字母在字母表中的位置,Pi表示明文字母在字母表中的位置,Ki表示密钥字母在字母表中的位置,i=1,2,3,…,n.根据维基利亚密码加密函数写出求密文的过程及密文字母在字母表中的位置如下表:wanaNyu220130132420songHua181413672001414062018203.看表可知:明文“wananyu”维基利亚加密后的密文字母在字母表中的位置为:141406201820因此密文为:OOAGUSU(2)编写程序:由维吉尼亚加密算法的原理可知,编写程序来实现维吉尼亚加解密主要是构造明文对应的数字表,在这里,可用将明文字母转化成其ACSII值,在这
4、之前,要将所有明文字母和密钥字母首先转化为大写字母,再转化成其对应的ACSII码值,将明文和密钥字母所对应的ACSII码带入加密或者解密公式,算出密文,再将密文还原成大写字母输出。四、实验流程:(1)本实验的明文如下:(2)实现明文文件的读取(3)实现密文文件的保存fputs(str3,fp2);*///注意不能使用fputs,否知出现意想不到的错误!!!fwrite(str3,1,m,fp2);//存入文件result.txt中。fclose(fp1);fclose(fp2);printf("加密成功,密文已存入result.txt文件中!");(4)解密后的密文如下:(5)统
5、计明文字母和密文字母的频率,并找出各自频率最大的5个字母;由相关数据计算密文的密表数。明文中频率最大的5个字母:密文中频率最大的5个字母:五、实验心得Vigenere密码比较简单,通过实验,我明白了密码的加密和加密过程,对维吉尼亚加密算法有了更深入和全面的认识,也更具体地了解到密码学的博大精深。通过编程,我复习C语言的知识,提高了C语言的能力,并且在设计算法的过程中提高了自己的逻辑思维能力和数学能力。通过与同组的同学讨论和解决问题,也开阔了自己的眼界和思维,如对数组和字符串函数的使用等等。六、实验分工小组成员具体工作刘鼎钧搜集资料,编写代码李静轩撰写实验报告,编写代码涂艾伶撰写实验报
6、告,编写代码
此文档下载收益归作者所有