- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验四:密码学 MD5 实验报告
专业: 计算机科学与技术 班级:2015 级 姓名:孟亚超 学号:20150402201006
实验名称 密码学 MD5
实验目 自学md5 原理,编写 MD5 算法,了解算法工作过程
MD5 是一个不可逆的算法,是单向的,通常用于签名验证
和一些不需要还原原文的算法,这种算法加密后就不能还
实验原理
原回原文,这种算法还原回原文有无穷种原文,所以理论
上是不可能被还原
1、 MD5 不可能被还原
注意事项
2、 MD5 算法加密后的长度是固定的,长度为 32 位
实验环境说明
Window7
Java jdk
Eclipse for EE
实验步骤
源代码
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;
public class EXEMD5 {
/*设置MD5值输出为16进制(从0到F)*/
protected static char hexDigits [] = { 0, 1,2, 3, 4, 5, 6, 7, 8,
9,A, B, C, D, E, F};
/*获取MD5算法,并判断是否存在MD5算法(判断是否正确导入了加密库)*/
protected static MessageDigest 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);
FileChannel 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);
}
/*将字节数组从第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++) {
您可能关注的文档
最近下载
- 2023会计年终工作述职报告7篇.docx VIP
- 法语语法总结ppt课件.pdf VIP
- 6《除法》单元整体设计 北师大四年级数学上册 .pdf VIP
- 小学生竞选大队干部演讲稿优秀.pptx VIP
- FSSC22000V6.0体系文件清单.docx VIP
- 情绪觉察水平量表.pdf VIP
- 20210916-IBM商业价值研究院-人工智能:应对AI数据困境:恰当的数据集成方法、治理和工具.pdf VIP
- DBJ50-T-185-2019_增强型改性发泡水泥保温板建筑保温系统应用技术标准.docx VIP
- SOP-QR-141MSA测量系统分析作业办法.doc VIP
- 几种常见医院感染.docx VIP
文档评论(0)