昆明理工大学网络安全实验报告5.MD5算法的实现.docVIP

昆明理工大学网络安全实验报告5.MD5算法的实现.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
昆明理工大学网络安全实验报告5.MD5算法的实现

昆明理工大学信息工程与自动化学院学生实验报告 ( 2011 —2012 学年 第 2 学期 ) 课程名称:网络安全 开课实验室:应用、网络机房442 2012 年12 月21日 年级、专业、班 计科093 学号 200910405310 姓名 孙浩川 成绩 实验项目名称 MD5算法的实现 指导教师 缪祥华 教师评语 该同学是否了解实验原理: A.了解□ B.基本了解□ C.不了解□ 该同学的实验能力: A.强 □ B.中等 □ C.差 □ 该同学的实验是否达到要求: A.达到□ B.基本达到□ C.未达到□ 实验报告是否规范: A.规范□ B.基本规范□ C.不规范□ 实验过程是否详细记录: A.详细□ B.一般 □ C.没有 □ 教师签名: 年 月 日 实验目的 1、对算法描述可进行充分理解,精确理解算法的各个步骤。 2、完成MD5软件算法的详细设计。 3、用java完成算法的设计模块。 4、编制测试代码。 实验原理及基本技术路线图(方框原理图) MD5即Message-Digest Algorithm 5(信息-摘要算法 5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5的前身有MD2、MD3和MD4。MD5的作用是让大容量信息在用数字签名软件签署私人密钥前被压缩成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。MD5以512位分组来处理输入的信息,且每一分组又被划分为16个32位子分组,经过了一系列的处理后,算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值。在MD5算法中,首先需要对信息进行填充,使其位长对512求余的结果等于448。因此,信息的位长(Bits Length)将被扩展至N*512+448,N为一个非负整数,N可以是零。填充的方法如下,在信息的后面填充一个1和无数个0,直到满足上面的条件时才停止用0对信息的填充。然后,在这个结果后面附加一个以64位二进制表示的填充前信息长度。经过这两步的处理,现在的信息的位长=N*512+448+64=(N+1)*512,即长度恰好是512的整数倍。这样做的原因是为满足后面处理中对信息长度的要求。MD5中有四个32位被称作链接变量(Chaining Variable)的整数参数,他们分别为:A=0B=0xefcdab89,C=0x98badcfe,D=0当设置好这四个链接变量后,就开始进入算法的四轮循环运算。循环的次数是信息中512位信息分组的数目。 选择并确定试验平台:可以选择可行的任意语言和系统平台,选择之前应进行论证。 设计数据结构和程序结构:根据DES算法,设计相应的数据结构和程序结构,并设计相应的界面。 实现算法:对设计好的程序结构和数据结构,在相应的平台下进行实现,对程序进行调试。 得出实验结果:对已经实现的程序,用不同的数据进行调试,验证程序结果的正确性。 所用仪器、材料(设备名称、型号、规格等) 计算机一台、vc6.0 四、实验方法、步骤 import java.awt.Color; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import javax.swing.*; public class MD5Frame extends JFrame implements ActionListener { private JTextField text_source,text_randomlist,text_now; private JTextArea text_area; private JButton button_list,button_compare; public MD5Frame() { this.setBounds(200, 200, 444, 400); JPanel panel_cente

文档评论(0)

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

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

1亿VIP精品文档

相关文档