zoukankan      html  css  js  c++  java
  • 哈希碰撞与生日攻击

    哈希碰撞与生日攻击

    一、哈希碰撞是什么?

    所谓哈希(hash),就是将不同的输入映射成独一无二的、固定长度的值(又称"哈希值")。它是最常见的软件运算之一。

    如果不同的输入得到了同一个哈希值,就发生了"哈希碰撞"(collision)。

    img

    举例来说,很多网络服务会使用哈希函数,产生一个 token,标识用户的身份和权限。

    AFGG2piXh0ht6dmXUxqv4nA1PU120r0yMAQhuc13i8
    

    上面这个字符串就是一个哈希值。如果两个不同的用户,得到了同样的 token,就发生了哈希碰撞。服务器将把这两个用户视为同一个人,这意味着,用户 B 可以读取和更改用户 A 的信息,这无疑带来了很大的安全隐患。

    黑客攻击的一种方法,就是设法制造"哈希碰撞",然后入侵系统,窃取信息。

    二、如何防止哈希碰撞?

    防止哈希碰撞的最有效方法,就是扩大哈希值的取值空间。

    16个二进制位的哈希值,产生碰撞的可能性是 65536 分之一。也就是说,如果有65537个用户,就一定会产生碰撞。哈希值的长度扩大到32个二进制位,碰撞的可能性就会下降到 4,294,967,296 分之一。

    更长的哈希值意味着更大的存储空间、更多的计算,将影响性能和成本。开发者必须做出抉择,在安全与成本之间找到平衡。

    下面就介绍,如何在满足安全要求的前提下,找出哈希值的最短长度。

    三、生日攻击

    哈希碰撞的概率取决于两个因素(假设哈希函数是可靠的,每个值的生成概率都相同)。

    • 取值空间的大小(即哈希值的长度)
    • 整个生命周期中,哈希值的计算次数

    这个问题在数学上早有原型,叫做"生日问题"(birthday problem):一个班级需要有多少人,才能保证每个同学的生日都不一样?

    答案很出人意料。如果至少两个同学生日相同的概率不超过5%,那么这个班只能有7个人。事实上,一个23人的班级有50%的概率,至少两个同学生日相同;50人班级有97%的概率,70人的班级则是99.9%的概率(计算方法见后文)。

    这意味着,如果哈希值的取值空间是365,只要计算23个哈希值,就有50%的可能产生碰撞。也就是说,哈希碰撞的可能性,远比想象的高。实际上,有一个近似的公式。

    img

    上面公式可以算出,50% 的哈希碰撞概率所需要的计算次数,N 表示哈希的取值空间。生日问题的 N 就是365,算出来是 23.9。这个公式告诉我们,哈希碰撞所需耗费的计算次数,跟取值空间的平方根是一个数量级。

    这种利用哈希空间不足够大,而制造碰撞的攻击方法,就被称为生日攻击(birthday attack)。






    文章转载自:http://www.ruanyifeng.com/blog/2018/09/hash-collision-and-birthday-attack.html

  • 相关阅读:
    js 函数声明和函数表达式的区别
    使用dom4j工具包对xml文件解析
    xml的schema约束
    xml的DTD约束
    C3P0连接池工具类使用
    jdbc连接警告不安全
    java的unity单元测试
    BootStrap容器介绍
    validate插件实现表单效验(二)
    validate插件实现表单效验(一)
  • 原文地址:https://www.cnblogs.com/k-class/p/13773154.html
Copyright © 2011-2022 走看看