密码学实验(MD5实验)

  • 格式:docx
  • 大小:578.48 KB
  • 文档页数:10

下载文档原格式

  / 10
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

密码学实验

——计算文件MD5值

姓名:

班级:

学号:

教师:

助教:

【1】Hash算法实验

(1)MD5\SHA1\SHA-256算法比较

A.【相同点】MD5,SHA1,SHA-256属于密码级散列函数,算法相对比较复杂,参与加密算法的过程中时也

比较安全,三者都是属于哈希算法一类,都是任意长

度的消息压缩到某一固定长度的消息摘要的函数B.【不同点】

MD5输出128bit

SHA1输出160bit

SHA256输出256bit

①普通密码可以用MD5,但数字证书和数字签名就法

定必须用SHA256

②MD5比SHA1快,SHA1比MD5强度高

C.截图

(2)相同与相似字符串MD5差异比较

【2】Hash算法过程与填充方式

【常见Hash算法的数据填充方式】

1.首位填充1,后面填满0位;【即:先补一个1,然后再补

0,直到长度满足对512取模后余数是448。】

2.补长度;【通常用一个64位的数据来表示原始消息的长度。

如果消息长度不大于2^64,那么第一个字就是0;如果原始的消息长度超过了512,我们需要将它补成512的倍数。

然后我们把整个消息分成一个一个512位的数据块,分别处理每一个数据块,从而得到消息摘要】

【3】计算文件MD5值

1.源代码【hello.exe\erase.exe文件放在其中的src文件夹中】package com.topcheer;

import 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;

publicclass EXEMD5 {

/*设置MD5值输出为16进制(从0到F)*/

protectedstaticchar hexDigits[] = { '0', '1','2', '3', '4', '5', '6', '7', '8', '9','A', 'B', 'C', 'D', 'E', 'F'};

/*获取MD5算法,并判断是否存在MD5算法(判断是否正确导入了加密库)*/

protectedstatic MessageDigest messagedigest = null;

static{

try {

messagedigest = MessageDigest.getInstance("MD5");

} catch (NoSuchAlgorithmException e) {

e.printStackTrace();

}

}

/*计算文件(包括EXE文件)MD5值的算法*/

publicstatic String getFileMD5String(File file) throws IOException{ FileInputStream in = new FileInputStream(file);

FileChannelch =in.getChannel();

MappedByteBufferbyteBuffer

=ch.map(FileChannel.MapMode.READ_ONLY, 0, file.length()); messagedigest.update(byteBuffer);

return bufferToHex(messagedigest.digest());

}

/*将字节数组转换为字符串类型*/

privatestatic String bufferToHex(byte bytes[]){

return bufferToHex(bytes, 0,bytes.length);

}

/*将字节数组从第m位元素到第n位元素的部分转换成字符串类型*/ privatestatic String bufferToHex(byte bytes[], int m, int n){ StringBufferstringbuffer =new StringBuffer(2 * n);

int k = m + n;

for (int l = m; l< k; l++) {

appendHexPair(bytes[l], stringbuffer);

}

return stringbuffer.toString();

}

privatestaticvoid appendHexPair(byte bt, StringBufferstringbuffer) { char c0 = hexDigits[(bt& 0xf0) >> 4];

char c1 = hexDigits[bt& 0xf];

stringbuffer.append(c0);

stringbuffer.append(c1);

}

publicstaticvoid main(String[] args) throws IOException{ System.out.println("请选择你要计算MD5值的应用程序文件!");

System.out.println("【1】erase.exe 【2】hello.exe");

int choose=new Scanner(System.in).nextInt();