网站大量收购独家精品文档,联系QQ:2885784924

实验1—古典密码算法—张儒雅.docxVIP

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
云南大学软件学院 实验报告姓名:张儒雅学号:20111120075专业:信息安全教师:金鑫实验目的通过编程实现替代密码算法和置换密码算法,加深对古典密码体系的了解,为以后深入学习密码学奠定基础。实验原理古典密码算法曾被广泛应用,大都比较简单。它的主要应用对象是文字信息,利用密码算法实现文字信息的加密和解密。其中替代密码和置换密码是具有代表性的两种古典密码算法。替代密码 替代密码算法的原理是使用替代法进行加密,就是将明文中的字符用其他字符替代后形成密文。例如,明文字母a、b、c、d,用D、E、F、G做对应替换后形成密文。最早的替代密码是由Julius Caesar 发明的Caesar (恺撒)密码,又叫循环移位密码。它的加密过程可以表示为下面的函数: E(m) = (m+k ) mod n其中,m为明文字母在字母表中的位置数;n为字母表中的字母个数;k为密钥;E(m)为密文字母在字母表中对应的位置数。 例如,对于明文字母H,其在字母表中的位置数为8,设k=4,则按照上式计算出来的密文为L,计算过程如下: E(8) = (m+k ) mod n = (8+4 ) mod 26 = 12 = L解密算法是:m = D(L) =(L-k)mod 26置换密码置换密码算法的原理是不改变明文字符,只将字符在明文中的排列顺序改变,从而实现明文信息的加密。置换密码又称为换位密码。矩阵换位法是实现置换密码的一种常用方法。它将明文中的字母按照给定的顺序安排在一个矩阵中,然后又根据密钥提供的顺序重新组合矩阵中的字母,从而形成密文。例如,明文为 attack begins at five ,密钥为 cipher ,将明文按照每行6个字母的形式排在矩阵中,形成如下形式: attack begins atfive根据密钥 cipher 中各字母在字母表中出现的先后顺序,得到给定的一个置换:f = 14 5 3 2 6因此有: 密钥: 145326 明文: attack begins atfive根据上面的置换,将原有矩阵中的字母按照第1列、第4列、第5列、第3列、第2列、第6列的顺序排列、则有下面的形式:aacttk binges aivfte从而得到密文:abatgftetcnvaiikse其解密过程是根据密钥的字母数作为列数,将密文按照列、行的顺序写出,再根据由密钥给出的矩阵置换产生新的矩阵,从而恢复明文。三.实验结果:1.替代密码中使用特定的公式将结果加密并得到结果,以此并加以加密和解密: 实验中的结果如下:流程图:在学习使用替换算法的时候,我首先对加密的公式即:E(m) = (m+k ) mod n进行学习,对其的工作方式进行了解并掌握,从而对其进行加密和解密算法的学习并编写程序,最后将其中所使用各种函数进行整合,以此编写替换算法,这种算法比较简单,过程较为简单。2.置换密码中使用二维数组对信息进行加密和解密,这中工作使信息安全性更好一些;记过如下:流程图:在写置换算法的时候,对置换算法没什么了解,因此在写置换算法的时候对其工作进程以及其过程做了较长时间的了解,最后因为这个算法较难,所以花费了较长的时间进行调试工作。代码:替代算法:#includestdio.h#includestring.h#includemath.hvoid jiami(){char str1[1000],str2[1000];int i,m,k,n,l; printf(请输入你要加密的明文:\n); scanf(%s,str1); printf(请输入要加密时的密钥:\n); scanf(%d,k); m=strlen(str1); printf(加密的明文长度是:%d,m); printf(加密后的密文是:);for(i=0;im;i++) { n=(int)(str1[i]);if(n96n123) { n = (n-97+k) % 26; l = (char)(n+97); printf(%c,l); str2[i]=l;} }}void jiemi(){int I,M,K,N,L;char str3[1000],str4[1000]; printf(请输入要解密的密文:\n); scanf(%s,str3); printf(请输入解密的密钥:\n); scanf(%

文档评论(0)

shaoye348 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档