密码学MD5实验报告_第1页
密码学MD5实验报告_第2页
密码学MD5实验报告_第3页
密码学MD5实验报告_第4页
密码学MD5实验报告_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上实验四:密码学MD5实验报告专业: 计算机科学与技术 班级:2015级 姓名:孟亚超 学号:006实验名称密码学MD5实验目的自学md5原理,编写MD5算法,了解算法工作过程实验原理MD5是一个不可逆的算法,是单向的,通常用于签名验证和一些不需要还原原文的算法,这种算法加密后就不能还原回原文,这种算法还原回原文有无穷种原文,所以理论上是不可能被还原的注意事项1、 MD5不可能被还原2、 MD5算法加密后的长度是固定的,长度为32位实验环境说明Window7 Java jdkEclipse for EE实验步骤源代码package com.topcheer; impor

2、t java.io.File;import java.io.FileInputStream;import java.io.IOException;import java.nio.MappedByteBuffer;import java.nio.channels.FileChannel;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;import java.util.Scanner; public class EXEMD5 /*设置MD5值输出为16进制(从0到F)*/ protec

3、ted static char hexDigits = '0', '1','2', '3', '4', '5', '6', '7', '8', '9','A', 'B', 'C', 'D', 'E', 'F' /*获取MD5算法,并判断是否存在MD5算法(判断是否正确导入了加密库)*/ protected static MessageDige

4、st messagedigest = null; static try messagedigest = MessageDigest.getInstance("MD5"); catch (NoSuchAlgorithmException e) e.printStackTrace(); /*计算文件(包括EXE文件)MD5值的算法*/public static String getFileMD5String(File file) throws IOException FileInputStream in = new FileInputStream(file); FileChan

5、nel ch =in.getChannel(); MappedByteBuffer byteBuffer =ch.map(FileChannel.MapMode.READ_ONLY, 0, file.length(); messagedigest.update(byteBuffer); return bufferToHex(messagedigest.digest(); /*将字节数组转换为字符串类型*/private static String bufferToHex(byte bytes) return bufferToHex(bytes, 0,bytes.length); /*将字节数组

6、从第m位元素到第n位元素的部分转换成字符串类型*/private static String bufferToHex(byte bytes, int m, int n) StringBuffer stringbuffer =new StringBuffer(2 * n); int k = m + n; for (int l = m; l< k; l+) appendHexPair(bytesl, stringbuffer); return stringbuffer.toString(); private static void appendHexPair(byte bt, StringB

7、uffer stringbuffer) char c0 = hexDigits(bt& 0xf0) >> 4; char c1 = hexDigitsbt& 0xf; stringbuffer.append(c0); stringbuffer.append(c1); public static void main(String args) throws IOException System.out.println("请选择你要计算MD5值的应用程序文件!"); System.out.println("【1】erase.exe 【2】he

8、llo.exe"); int choose=new Scanner(System.in).nextInt(); File exe=null; if(choose=1) exe = new File("./src/erase.exe"); else if(choose=2) exe = new File("./src/hello.exe"); else System.out.println("非法输入,请重新运行程序! "); System.exit(0); long beginTime=System.nanoTime();

9、String md5=getFileMD5String(exe); long endTime =System.nanoTime(); double time=endTime-beginTime; System.out.println("【运行结果】"); System.out.println("选择的文件是: "+exe.getName(); System.out.println("该文件MD5值: "+md5); System.out.println("计算MD5用时: "+(time/)+"毫秒"); 程序运行结果截图实验结果分析我们不难发现,这两个EXE文件虽然内容不同,但是MD5值却是相同的!MD5,用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译、),主流编程语言普遍已有MD5实现。MD5算法具有以下特点:1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。2、容易计算:从原数据计算出MD5值很容易。3、抗修改性:对原数据进行任何改动

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论