- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
密码实验报告2 (800字)
密码实验报告2 (800字)
该实验为验证性实验。
通过本实验,使学生对于两种基本的古典密码编码方法(“代替”与“移位”) 产生深刻的感性认识,体验清楚二者之间的本质差异,为理解和掌握现代密码的相应知识打下良好基础。
二、实验内容
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. 代替密码
#includelt;stdio.hgt;
#includelt;time.hgt;
#includelt;string.hgt;
#includelt;ctype.hgt;
#includelt;stdlib.hgt;
/*声明子函数*/
unsigned char *full_array2(char n); /*fully_array函数产生随机数*/ int letter_to_digit(char c);
char digit_to_lette
文档评论(0)