为什么应该放弃或减少使用MD5

MD5即Message-Digest Algorithm 5(信息-摘要算法 5),是网络上广泛使用的散列(Hash)算法之一,可以实现将任意长度的数值映射为固定长度的较小数值。

  MD5是一种常用的单向Hash算法。它被广泛用于以下几个用途:

  1、检查数据是否一致。将两地存储的数据进行哈希,比较结果,如果结果一致就无需再进行数据比对。这是利用了其“抵抗冲突”(collision- resistant)的能力,两个不同的数据,其哈希值只有很小的几率一致。相当多数据服务,尤其是网盘服务,利用类似的做法来检测重复数据,避免重复上传。

  2、存储用户密码。将密码哈希后的结果存储在数据库中,以做密码匹配。这是利用了其做为单向哈希的特点,从计算后的哈希值不能得到密码。

  3、校验数据正确性。将数据和数据哈希后的结果一并传输,用于检验传输过程中数据是否有损坏。这是利用了很难找到两个不同的数据,其哈希结果一致的特点。

  下面我们将说明为什么对于上面三种用途, MD5都不适用。

  第一个用途尤其可怕。这个用途的最大的问题是,MD5在现实中已经被发现有相当多的数据都可能导致冲突。举例而言,如下两段数据的MD5哈希值就是完全一样的。

    数据 1 

    4d c9 68 ff 0e e3 5c 20 95 72 d4 77 7b 72 15 87
    d3 6f a7 b2 1b dc 56 b7 4a 3d c0 78 3e 7b 95 18
    af bf a2 00 a8 28 4b f3 6e 8e 4b 55 b3 5f 42 75
    93 d8 49 67 6d a0 d1 55 5d 83 60 fb 5f 07 fe a2

    数据 2

    4d c9 68 ff 0e e3 5c 20 95 72 d4 77 7b 72 15 87
    d3 6f a7 b2 1b dc 56 b7 4a 3d c0 78 3e 7b 95 18
    af bf a2 02 a8 28 4b f3 6e 8e 4b 55 b3 5f 42 75
    93 d8 49 67 6d a0 d1 d5 5d 83 60 fb 5f 07 fe a2

    输出相同的MD5 哈希

    008ee33a9d58b51cfeb425b0959121c9

  这意味着,如果用户提供数据 1,服务器已经存储数据 2。通过简单的MD5哈希方式检查重复,服务器上为用户保存的数据就是2。 接下来发生的事情大家都知道了,就是用户数据丢了!

  第二个用途很容易遭到rainbow table攻击,和明文存储密码的实质区别不大。更详细的分析可以察看这篇文章

  第三个用途里一般会在需要哈希的数据中混入某些秘密,也就是计算公式为md5(secret key + data)。 但这样并不适合用于验证数据的完整性。这是因为,从理论上上来说,如果知道md5(secret key +X),即使不知道secret key的内容, 仍然可能通过对X的分析,计算得到md5(secret key +Y),从而将X成功的替换成Y,导致接收方仍然认为数据是正确的。

时间: 2024-09-17 23:55:04

为什么应该放弃或减少使用MD5的相关文章

Flipboard发布了一个“功能不完整”的网页版?

自从 Flipboard 推出了带杂志制作功能的 2.0 版本http://www.aliyun.com/zixun/aggregation/12459.html">移动客户端以来,他们的用户数量增加了 200 万,目前已经总注册用户数已经达到 7500 万.Flipboard 目前正式发布了桌面网页版,用户现在已经可以在网页上阅读来自其他用户分享的个性化杂志,但却仍然缺失移动客户端上的很多功能. 功能不完整的网页版 Flipboard 并不是直接把移动平台应用照搬到网页上,如果你访问 F

解放日报:网瘾标准同一化是否可行

上海师范大学应用心理学系教授.博士生导师 顾海根 问:日前,中国青少年网络协会发布了<中国青少年网瘾报告(2009)>.调查结果显示,目前我国城市青少年网民中,网瘾青少年占了14.1%,约2404.2万人.网瘾诊治标准的制订一直备受关注.对于将初步以每周上网40小时以上即认为是网瘾的界定标准,引来不少 网友争议.请问,能否仅凭上网时间就可诊断网瘾?网瘾标准同一化是否可行? --东方网网友 风吹稻花 答:能否光凭上网时间就可诊断网瘾的问题,确实需要澄清一下.对此,首先要回答什么是网瘾.网瘾是网络

彭小峰:如果没有入世我可能不会创立赛维LDK

叶慧珏 上海报道 18岁开始创业,先从事进出口贸易,后转作实体经济,专门生产劳保产品--这是彭小峰的前十年创业经历. 在中国加入世界贸易组织(WTO)五周年之际,看准太阳能光伏产业的全球贸易机会,一手创立江西赛维LDK太阳能高科技有限公司,专心从事太阳能多晶硅片生产,第二年公司就在纽交所挂牌上市,当年身家超过耕耘太阳能产业已经六年的无锡尚德集团董事长施正荣,成为中国"新能源首富",如今江西赛维已经在全球布点,开拓新的消费市场--这是彭小峰最近五年的创业经历. 而这后来的五年,正是中国&

针对部分不法增值业务提供商通过在手机终端违规内置增值业务

针对部分不法增值业务提供商通过在手机终端违规内置增值业务,并扣取用户费用来谋取不正当利益的行为,中国移动于7月1日启用"梦网业务扣费主动提醒"功能.也就是说,梦网业务在订购扣费之前,将向用户发送二次确认的短信.另外,点播类梦网业务主动扣费提醒规则将于9月1日启用. 这使得SP偷偷扣取用户费用几乎不可能,并直接导致相关公司第三季度收益受损.此前,新浪.搜狐.腾讯等门户网站的移动增值收入已是逐季减少. 一些大型上市公司正在放弃或减少这部分资产.如华友世纪与盛大网络近期互换资产后,已完全退出

中钢天源高新复审选择性公告涉嫌信披违规

着名投资大师巴菲特有句名言,只有退潮了,才知道谁在裸泳.这对于当前中国证券市场中普遍存在的通过定向增发来改善自身境遇的上市公司而言,同样适用. "涉矿"是时下诸多上市公司提升身价的良计.中钢天源似乎也不甘置身事外,中钢天源(002057.SZ)近期发布了不超过2.5亿元的定增方案.如果说中钢天源投资选矿设备的定增项目属实,那么,中钢天源可谓与"涉矿"概念也沾上了边. 不过,中钢天源于2011年通过高新技术企业复审,不仅没有公告,其证券投资部人士还称这是"选

恒瑞医药“半价”股权激励遇冷

曾被业内一致看好的江苏恒瑞医药股份有限公司股票激励方案,遭到了公司中高层管理人员的冷待.昨晚恒瑞医药发布的董事会决议公告显示,有3名激励对象放弃认购,12名激励对象减少认购,合计有88.87万股激励股份无人认领.以目前20.28元/股的行权价格和二级市场40.28元/股的价差计算,1777.4万元账面收益已被悉数拱让. 根据公告,3名放弃认购的激励对象分别是恒瑞医药的副总经理蒋素梅,放弃认购17万股激励股票,另有两研发骨干均弃认购3万股.在12名减少认购的人员中,公司副总李克俭减少最多,减少认购

用C++ Builder的MD5控件实现软件防护

一.共享==免费? 随着Internet大行其道,"共享+注册"模式日渐成为程序员发布自己软件的主要手段,但是随之而来的破解手段也越来越高明.如何保护自己的劳动成果不被暴力破解或修改?用MD5摘要值验证是一个很常用的方法. MD5作为一个公开算法,实现的方法很多,比如开源软件.Windows自带的API等,C++ Builder和Delphi中集成的Indy里面也有现成的MD5控件.用API实现MD5虽然效率高,但是毕竟太繁琐,具体方法可以参阅MSDN上crypt开头的那几个函数说明.

技巧:利用javascript实现md5的本地加密

javascript|技巧|加密 md5($_POST['passwd']这就是php一般的加密方法,传过来后与数据库原来加密的md5代码进行比较 而下面介绍的方法是通过js来实现的md5,其实这种方法在很多其他的地方都有介绍,而yahoo,vBulletin 等等在没有用ssl加密登录时候就用这种方法,对密码加密 其实还有其他加密的部分方法也有实现:如md4/sha-1 首先你要去 md5的js下载地址/ 下载一个js的使用代码 调用: CODE: <script type="text/

为了网站,我放弃了学业!

时间过的真快,好久都没有写东西,其实每天都有要写东西的想法,但又不知道写什么了,不想写一些展示自己无知的技术文章了,生活琐事更是不值一提,思想上感觉已经没有什么可写的了,以后我会用文字慢慢的把自己内心都表露给大家. 06年8月的时候,我在自己的BLOG里写下了这样子的一段话:"暑假就在迷迷糊糊中过去了一大半,想到马上开学的9月自己都大3了,也快毕业了,心里其实也挺复杂的,突然一下想起了CCTV那句著名的广告词:"人生就象是旅行...不必在乎目的地...在乎的...只是沿途的风景以及看风