`

为什么应该放弃或减少使用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,导致接收方仍然认为数据是正确的。

分享到:
评论

相关推荐

    com.cortexm0.exception.StackUnderflowException(解决方案).md

    - 优化代码以减少堆栈使用:审查代码中是否存在不必要的递归调用,并尽可能地将它们替换为循环或更高效的数据结构。同时,应避免在堆栈上分配大量数据,尤其是在ISR中,可以使用静态内存存储数据来减少堆栈使用。 ...

    序列化失败异常解决办法.md

    对于复杂对象,将其转换为简单类型(如列表、字典等)通常能够减少序列化时发生错误的可能性。而且,确保对象中没有包含无法序列化的元素,如文件句柄、网络连接等,如果这些内容存在,在序列化之前需要将其移除或...

    com.pureharmony.exception.ResourceLockException.md

    此外,合理的资源管理也是避免死锁的关键,比如尽量减少锁定资源的时间,以及优先使用无锁编程技术(比如使用原子操作类)。 在鸿蒙开发中遇到的ResourceLockException异常问题,可以通过合理的同步机制和异常处理...

    System.Threading.ThreadInterruptedException(解决方案).md

    重新设计意味着放弃使用中断机制来控制线程行为,而是引入其他形式的控制方式,如使用显式的取消标志或条件变量。这类设计可以更清晰地表达程序的行为,而且可以避免线程中断引发的异常处理逻辑,减少潜在的错误和不...

    com.harmonyos4.exception.TaskInterruptionException.md

    在HarmonyOS开发过程中,开发者可能会遇到一个特定的异常——TaskInterruptionException。这个异常表明一个任务在执行...只有这样,才能开发出高质量的应用程序,满足用户的使用需求,并推动项目的成功落地和广泛使用。

    ResourceDeadlockException.md

    资源死锁,简单来说,就是两个或多个进程在执行过程中,因争夺资源而造成的一种僵局,它们之间形成一种互相等待对方释放资源的循环等待关系,从而导致进程无法向前推进。死锁问题不仅影响程序的运行效率,严重时甚至...

    DistributedLockFailureException.md

    如果锁已经被占用,根据业务需求,程序可以选择等待一段时间后再尝试获取锁,或者直接采取其他的异常处理逻辑,比如放弃获取锁或通知用户。 其次,实现重试策略可以有效应对临时性网络波动或短暂的资源竞争。通过...

    exception.NetworkCongestionException(解决方案).md

    包括网络的容错设计,如设置超时机制,当网络请求超过设定的超时时间后,自动放弃此次请求,避免程序长时间等待而影响用户使用。此外,也可以通过备份机制,比如多服务器部署,保证在某一个节点出现异常时,其他节点...

    41源码 9:如履薄冰 —— 懒惰删除的巨大牺牲(2).md

    标题中提到的“懒惰删除”是指Redis数据库的一种内存管理机制,它涉及到数据删除操作的...此外,放弃对象共享机制虽然为懒惰删除提供了便利,但同时也对Redis的内存优化策略提出了挑战,需要重新设计内存管理的架构。

    最大子序列和问题的求解.md

    改进穷举法,减少内层循环的次数,使时间复杂度降为 \( O(N^2) \)。 ```cpp int maxSubSum2(const vector<int>& a) { int maxSum = 0; for (int i = 0; i (); ++i) { int thisSum = 0; for (int j = i; j (); +...

    为什么您应该停止使用Gerrit:有关为何应停止使用Gerrit并找到以隐私为中心的高效替代方案的文章

    标题中的“为什么您应该停止使用Gerrit”表明了文章的核心议题,即对Gerrit代码审查系统的批评以及探讨寻找更注重隐私且高效的替代方案。Gerrit是一款广泛用于开源项目,尤其是那些遵循GPLv3(GNU General Public ...

    ERR_DEADLOCK_DETECTED(解决方案).md

    ERR_DEADLOCK_DETECTED是数据库操作中一种典型的错误,它通常出现在多个客户端或进程尝试访问和修改相同数据时,由于彼此之间相互等待对方释放锁而无法继续执行操作,从而导致死锁状态。为了避免和解决这类问题,...

    【人脸识别】基于matlab GUI人脸识别课堂点名【含Matlab源码 C017期】.md

    实用性方面,系统应以经济实用为原则,为系统维护人员提供关键信息,形成即时的管控对策,确保系统的有效运转。 对于有志于学习Matlab技术的科研人员或学生,可以通过个人主页提供的联系方式获取Matlab项目合作机会...

    SDCC语法的STC15单片机头文件.zip

    “README.md”是常见的文件名,通常用于提供项目的说明或读我文档,可能包含了如何集成和使用这些头文件的具体指南。 这个压缩文件是专为SDCC编译器打造的STC15单片机开发资源,提供了一系列的头文件,帮助开发者...

    j2me 登录 注册

    J2ME虽然功能有限,但仍可使用如MD5或SHA系列的哈希算法对密码进行单向加密,这样即使数据被盗,也不能直接还原密码。另外,应支持用户修改密码,修改过程同样需要验证旧密码并更新新密码的哈希值。 6. **错误处理*...

    为什么您应该停止使用Google材料设计:有关为何您应停止使用Google材料设计并找到以隐私为中心的有效替代方案的文章

    标题和描述都在探讨一个主题——为何应该放弃使用Google的Material Design,并寻找以隐私保护为核心的设计方案。Material Design是Google推出的一种视觉设计语言,它为应用程序和网站提供了一套统一的设计规范,包括...

    商品价位表展示网站模板是一款适合电子商务网站结算弹出模板 .rar

    用户在使用模板前,应该先阅读这份文档,以了解如何正确部署和配置模板,避免遇到兼容性或功能问题。 总的来说,商品价位表展示网站模板是电子商务网站提高转化率和用户体验的重要工具。通过合理设计和有效利用,它...

    teste-b2w:开展一项工作来查找电子商务客户遗弃的购物车。 尽管主题很丰富,但在测试中将简化购物车放弃的定义

    5. 报告文档(如report.md或report.html):总结分析结果和建议。 在Python中,我们可以使用Matplotlib和Seaborn库进行数据可视化,帮助我们更好地理解数据。通过分析购物车放弃的时间间隔、用户浏览历史、设备类型...

    Project-Euler:我对Euler项目问题​​的解决方案(已放弃)

    - **优化算法**:寻找最有效的算法,减少时间或空间复杂度。 - **递归与分治**:将大问题分解为小问题,通过递归或分治策略求解。 - **动态规划**:存储中间结果以避免重复计算,提高效率。 - **枚举与搜索**:对...

    Magento-addressAutoComplete:Magneto 结帐地址自动完成

    - `README.md` 或 `INSTALLATION.md`:安装和使用指南。 要安装和使用此模块,你需要按照文档指示将文件上传至 Magento 根目录的相应位置,然后在后台启用模块,配置可能的设置,如 API 密钥或地区限制。在实际部署...

Global site tag (gtag.js) - Google Analytics