文章目录

  • 1.MD5 简介
  • 2.MD5 应用场景
  • 3.MD5 生成的 Hash 值为什么不可逆
  • 4.王小云院士真地破解了 MD5 吗
  • 5.结论
  • 参考文献

1.MD5 简介

MD5(Message-Digest Algorithm 5)是一种被广泛使用的消息摘要算法,也称为哈希算法、散列算法或杂凑算法,可以产生出一个定长的 128 位(16 字节)的散列值(Hash Value),一般用于数字签名以确保信息传输完整性与密码的加密存储。MD5 由美国密码学家罗纳德·李维斯特(Ronald Linn Rivest)设计,于 1992 年公开,用以取代 MD4 算法。

2.MD5 应用场景

一个安全的散列算法需要满足如下两个条件,也是散列算法的两个特性。
(1)抗碰撞性。根据一个输入,找到一个其它输入得到相同的输出,在计算上是不可行的;
(2)不可逆性。根据一个输出,找到一个输入其散列值等于输出,在计算上是不可行的,即不可能从结果逆向推导初始值。

注意,抗碰撞性并不是说散列算法无碰撞,无碰撞的算法不可能是一个散列算法,而只能是一个无损压缩算法,因为散列算法在计算过程中必然会丢失原文部分信息。

MD5 作为一个应用广泛散列算法,满足上述两个特点。根据第一个特点,MD5 可用于信息的数字签名用来验证信息传输的完整性和发送者的身份认证。根据第二个特点,MD5 可用于用户密码的散列存储。

(1)信息的数字签名。
对重要信息进行 MD5 计算生成散列值,作为信息的数字签名,用于确定信息在传输过程中是否被篡改以及发送者的身份认证。

(2)用户密码的散列存储。
常见用途就是网站敏感信息加密,比如用户名密码。将用户密码进行散列计算后落地存储,即使被拖库,用户的密码仍是安全的,因为 MD5 算法的不可逆性决定无法通过散列值逆向推算出密码。当然,密码破解有很多方法,比如暴力破解、彩虹表等,还是有可能从正向破解密码散列值的。

3.MD5 生成的 Hash 值为什么不可逆

因为 MD5 算法里面有很多不可逆的运算,会丢失很多原文的信息,无法找回,所以是不可逆的。比如移位,假设:10010001 左移两位后是01000100,你没有什么办法把它移回来。

4.王小云院士真地破解了 MD5 吗

所谓的“破解”其实误导了很多人,并不是说扔给王小云一个 MD5 散列值,然后她马上就能算出一个原文来。从密文推算出明文理论上是不可能的,所以王小云的研究成果并不能通过 MD5 的散列值逆向推算出明文。即给定 Hash 值,王小云不能逆向计算出 M。

MD5(M)=Hash

其中 M 指密码的明文,Hash 表示密码散列后的密文。

实际上,王小云的研究成果如下:

MD5(M1)=MD5(M2)

即给定消息 M1,能够计算获取 M2,使得 M2 产生的散列值与 M1 产生的散列值相同。如此,MD5 的抗碰撞性就已经不满足了,使得 MD5 不再是安全的散列算法。这样一来,MD5 用于数字签名将存在严重问题,因为可以篡改原始消息,而生成相同的 Hash 值。

这里,简单地用王教授的碰撞法给大家举个简单的例子。假如用户 A 给 B 写了个 Email 内容为 Hello,然后通过王教授的碰撞法,可能得到 Fuck 这个字符串的摘要信息和 Hello 这个字符串产生的摘要信息是一样的。如果 B 收到的 Email 内容为 Fuck,经过 MD5 计算后的,B 也将认为 Email 并没有被修改!但事实并非如此。

王小云院士的研究报告表明,MD4,MD5,HAVAL-128,RIPEMD 和 SHA-1 均已被证实存在上面的漏洞,即给定消息 M1,能够找到不同消息 M2 产生相同的散列值,即产生 Hash 碰撞。

5.结论

虽然 MD5、SHA1 已经被证实在数字签名存在安全问题,但是 MD5、SHA1 在密码的散列存储方面还是很安全的算法,只要密码足够复杂,加盐且迭代次数足够多,抗得住主流的口令破解方法,如暴力破解、彩虹表、字典攻击、词表重整攻击、概率上下文无关文法等。


参考文献

[1] 王小云的报告
[2] 关于王小云破解MD5之我见
[3] 关于HASH和MD5,王小云教授的“解密”
[4] 吕吕.基于DCR系统的多功能口令恢复平台[D].华南理工大学

王小云院士真地破解了 MD5 吗相关推荐

  1. 王小云院士真地破解了MD5吗

    转自:Dablelv 原文链接:https://blog.csdn.net/K346K346/article/details/87938911 1.MD5简介 MD5(Message-Digest A ...

  2. 祝贺!王小云院士连获两项国际大奖

    开年以来,山东大学网络空间安全学院(研究院)院长,双聘院士.讲席教授王小云先后获得"最具时间价值奖"和"真实世界密码学奖"两个国际奖项. 王小云,出生于山东诸城 ...

  3. [区块链与密码学][王小云院士][部分PPT][20200507]

  4. 破解密码高手王小云教授简介

    王小云教授,1966年生于山东诸城,1983年至1993年就读于山东大学数学系,先后获得学士.硕士和博士学位,导师潘承洞.1993年毕业后留校任教.2005年获国家自然科学基金杰出青年基金资助,同年入 ...

  5. 王小云破解了美国密码吗?

    王小云院士破译美国密码的消息曾经被传播得铺天盖地,这事是真的吗? 王小云确实是很了不起,她的科研成果也绝对是世界级的重大成就.但是,与破译美国密码毫不沾边. 王小云的工作成果是实现了MD5和SHA1两 ...

  6. 密码学领域重大发现:山东大学王小云教授成功破解MD5

    密码学领域重大发现:山东大学王小云教授成功破解MD5 [日期:2004-09-05] 来源:山东大学 作者: [字体:大中小] 转自山东大学 [本站讯]2004年8月17日的美国加州圣巴巴拉,正在召开 ...

  7. 女解码高手王小云 十年破译五部顶级密码 图

    女解码高手王小云:十年破译五部顶级密码(图) http://www.sina.com.cn 2006年12月22日 07:57 竞报   清华大学和山东大学的双聘教授王小云 她十年内破译 五部顶级密码 ...

  8. 王小云:十年破译五部顶级密码

    <!--正文内容开始--> <!-- 正文内部文字导航 : begin --> 她十年内破译 五部顶级密码 -她,比<暗算>里的"黄依依"还要聪 ...

  9. 王小云:连破两套美国顶级密码,获得711万奖励,美国不淡定了

    说起关乎国家安危的技术,军事迷们一定能在第一时间联想到核技术和航天技术.可是作为同为国家安全三大支撑技术之一的信息安全密码技术却鲜有人知. >>>> 密码技术到底有多重要和可怕 ...

最新文章

  1. linux epoll用法
  2. python dict排序 reduce函数
  3. struts2下拉框在不同情况下的各种用法
  4. Spring整合Mybatis之注解方式,(注解整合Junit)
  5. 前端学习(571):margin负值下的两栏自适应
  6. SQL Server 数据库构架
  7. 01-06 Linux常用命令-统计
  8. java做jsp问题_java/jsp中 中文问题详解
  9. Cmd Markdown编辑器简明语法手册
  10. 从“谈芯”走向“用芯” RISC-V 未来前景光明?
  11. 中国移动飞信的研究 笔记二
  12. 最小环flody hdu6080
  13. JZ2440 ping不通电脑的一种可能原因 PING 192.168.88.226 (192.168.88.226): 56 data bytes
  14. 三菱Q系列PLC数据采集随笔
  15. webstorm 下载安装及破解
  16. jQuery表格导出Excel文件以及网页内容导出Word文档
  17. PHP借用Redis消息队列实现高并发下发送邮件功能
  18. MicrosoftExcel函数
  19. 线程3 boost::future
  20. linux下oled显示设计,OLED显示问题

热门文章

  1. 《强化学习周刊》第55期:LB-SGD、MSP-DRL对抗鲁棒强化学习
  2. 学习《C++ Primer Plus》习题篇1 第六版第6章习题
  3. SOLIDWORKS直播课:解锁3DE协同设计平台的“云端结构设计角色”
  4. 2017爱创课堂vue.js视频完整版
  5. matlab——计算VPD(vapor pressure defict)
  6. git pull 报错:error: Pulling is not possible because you have unmerged files.
  7. AD20 PCB导出Gerber、拼板,华秋DFM一键拼板,同理支持其他PCB EDA软件的Gerber导入与拼板
  8. 解锁网易云音乐客户端变灰歌曲
  9. 工厂模式(简单工厂,工厂方法,抽象工厂)
  10. 心电监护仪数据图解_心电监护仪原理和使用步骤详解