生日悖论与Hash函数的攻击

article/2025/3/7 5:31:16

生日悖论与Hash函数的攻击

  • 生日悖论问题
    • 什么是生日悖论问题
    • 生日悖论问题求解
  • Hash函数的攻击
    • 两个集合相交问题
    • Hash函数的攻击方法
    • Yuval攻击

生日悖论问题

什么是生日悖论问题

假定每个人的生日是等概率的,在不考虑闰年的情况下每年有365天。在k个人中至少有两个人的生日相同的概率大于1/2,问k的最小值是多少?

生日悖论问题求解

把每个人的生日看成在[1,365]中的随机变量,由组合基本知识得知k个人的生日不相同的概率为:
在这里插入图片描述
设k个人的生日至少有一个相同的概率为P(k)。

当k = 23时,pk ≈ 0.4927,从而P(23) = 1-pk ≈ 0.5073 > 0.5

我们将k的值设置为100,此时,P(100) = 1- pk ≈ 0.9999997,即该事件几乎必然发生。

下表为k取不同值时P(k)的值。

kP(k)
100.1169
230.5073
300.7063
400.8912
500.9704
600.9941
1000.9999

,在k = 40的时候,P(k)的值竟然已经高达了0.9!这个结果和我们一贯的直觉并不一致。因此被称为生日悖论

其实,如果从k个人中抽出一个人,其他人与这个特定的人具有相同生日的概率将会是非常的小的,只有365-1。但是,如果我们并不指定特定的日期,仅仅只是寻找两个生日相同的人,那么问题就会非常的容易,在相同的范围内成功的概率也会大得多。

Hash函数的攻击

对于输出长度为128比特的Hash函数求碰撞,便类似于以上我们介绍的生日悖论问题的情况。即:

要找到与一个特定的消息具有相同散列值的另一个消息的概率很小,但是如果不指定特定的散列值,只是在两组消息中找到具有相同散列值的两个消息,那么问题就会简单的多。

两个集合相交问题

已知两个k元集合X={x1,x2,…,xk},Y={y1,y2,…,y1},其中xiyj,1≤i,j≤k是{1,2,…,n}上均匀分布的随机变量。取定xi,如果xi=yj,则称xi和yj匹配

固定i,j,则yj与xi匹配的概率为n-1,那么其不匹配,即xi≠yj的概率为1-n-1

Y中所有k个随机变量都不等于xi的概率为(1-n-1)k

如果X,Y中的k个随机变量两两互不相同,则X与Y中不存在任何匹配的概率为(1-n-1)k*k

从而X与Y至少有一个匹配的概率为p=1-(1-n-1)k*k

由数学知识知,当n趋近于无穷时,(1 + x/n) = ex,所以有:p=1-(1-n-1)k×k≈1 - (e-1/n)k×k

如果我们令p大于0.5,则可求得:k = [(ln2)×n]0.5 ≈ 0.83(n)0.5 ≈ n0.5

Hash函数的攻击方法

“两个集合相交”问题可以转述为:假设Hash函数h输出的长度为m,全部可能的输出有n = 2m个。Hash函数接收k个随机输入产生X,接收另外k个随机输入产生Y。

根据之前的讨论知,当取k = 2m/2时,X与Y至少存在一对匹配的概率大于0.5,即Hash函数产生碰撞的概率大于0.5。由此可知,2m/2将决定输出长度为m的Hash函数H抗碰撞的强度。

在通常情况下,攻击者利用上述原理生成Hash函数碰撞,达成其攻击目的的攻击称为生日攻击,也称为平方根攻击。对于输出长度为m的Hash函数,其攻击复杂度为2m/2

例如,当Hash被用于数字签名方案以产生消息签名。如果攻击者可以找到两个碰撞的消息x和x’,使得这两个消息的摘要相等,那么攻击者就可以根据需要,使用适当的消息(x或x’)和消息签名相匹配,以达到诬陷、抵赖等目的。

注意:数字签名算法通常是对表达一定含义的消息进行处理,并非随机输入。

Yuval攻击

Yuval攻击的原理是攻击者通过对有意义的消息,加入空格、改变写法或格式,但保持含义不变,产生2m/2个不同的消息变形,即产生一个相同含义的消息组。具体过程如下:

(1)攻击者A准备好合法的消息x,再拟定一个准备替换消息x的假消息x’。

(2)攻击者对消息x产生2m/2个变形的消息(含义不变),同时产生x‘的2m/2个变形消息,计算所有这些消息的Hash值。

(3)比较这两个散列函数值集合,以便发现具有相同散列值的消息。根据生日悖论,两个相交集合问题成功的概率大于0.5.如果没有发现,那么再产生一批合法消息和假消息,直到出现一个匹配为止。

(4)攻击者将消息x发送给签名者A,得到其签名。

(5)用匹配的假消息x’代替x,后面依然附加A的签名,并将其送给接收方B。


http://chatgpt.dhexx.cn/article/mTOcSl1w.shtml

相关文章

消息完整性和哈希函数 哈希碰撞与生日攻击 HMAC (Message Integrity and Hash Function)

消息完整性和哈希函数 1. Message Integrity - 消息的完整性1.1 消息安全性和消息完整性的联系 2. Message Authentication Code - 消息认证码2.1 Defination2.2 MAC 安全的定义2.2 Replay Attacks - MAC的不足2.3 MAC Contruction for Fixed-length Message2.4 (Basic) CBC - …

哈希碰撞与生日攻击

一、哈希碰撞是什么? 所谓哈希(hash),就是将不同的输入映射成独一无二的、固定长度的值(又称"哈希值")。它是最常见的软件运算之一。 如果不同的输入得到了同一个哈希值,就发生了&q…

用生日攻击方法求解离散对数问题(C语言实现)-大三密码学实验

实验原理: 生日攻击:输入为生成元a的阶p-1和元b,输出为离散对数。设置两个长度为p的列表: 1)列表1包含,通过随机选取p个k得到; …

抗碰撞性、生日攻击及安全散列函数结构解析

回顾一下,密码学的上篇是完整性,完整性的保证是由一段定长的散列,俗称tag来确定的。又因为tag是定长的,而需要确保完整性的内容种类却可以认为是无限的。因此总有tag(mi)tag(mj),mi ! mj,因此我们要引入抗碰…

密码学之生日攻击 离散对数问题求解 python实现

生日攻击 离散对数问题( DLP ) 给定素数 p, α \alpha α, β \beta β 是模 p 非零的整数,令 β α x m o d p \beta \alpha^x\mod p βαxmodp ,则求 x 的问题称为离散对数问题。 生日攻击是一种密码攻击,它利…

Hash函数与生日攻击

简介 Hash函数也叫杂凑函数、散列函数、哈希函数,可以把消息或数据压缩成固定长度的摘要 性质 等长性:给出任意的输入,得到的输出(摘要)长度不变。比如sha-1得到的摘要固定是160位,md5为128位单向性&#…

【Hash函数与生日攻击】

文章目录 一、Hash函数Hash函数关于密钥s散列函数定义碰撞发现实验-可忽略的散列函数安全性的三个典型的安全水平通用生日攻击 参考文献 一、Hash函数 Hash函数 将任意长度字符串压缩成短字符串的函数 关于密钥s 散列函数定义 碰撞发现实验-可忽略的 最强的安全性要求&…

生日攻击理解

1.什么是哈希碰撞?产生哈希碰撞的原因是什么?如何避免? 两个不同的输入,经过哈希算法后,得到了同样的哈希值,就叫做哈希碰撞。由于通常的哈希算法中,哈希值的空间远小于输入的空间,这…

哈希碰撞与生日相同概率

一、哈希碰撞是什么? 所谓哈希(hash),就是将不同的输入映射成独一无二的、固定长度的值(又称"哈希值")。它是最常见的软件运算之一。 如果不同的输入得到了同一个哈希值,就发生了&q…

密码学系列之:生日攻击

简介 生日攻击其实是一个概率论的问题,也就是说一个看起来很难发生的事情,事实上它发生的概率却很大。这种主观上和事实上的概率差距,让随机攻击成功的几率变的更高,这样的攻击就叫做生日攻击。 生日问题的由来 生日问题也叫做…

linux 清空redis缓存

1,进入目录redis下src目录。 #cd redis-2.8.17/src 2,执行redis-cli文件 #./redis-cli 3,执行命令:flushall,出现OK代表执行成功 #flushall 4,退出命令exit #exit 实例:

【redis】linux服务器清空redis

redis-cli 进入redis命令行 flushall 清除所有 如果报出“NOAUTH Authentication required.”错误,那么需要用密码授权 使用 auth [密码] 就可以继续操作了

redis数据清空脚本

redis服务经常因服务器内存不够用而自动死掉。需要经常连接进去做数据清理后启动服务。 所以写了个脚本每天清理一遍。 echo "flushall" | redis-cli -p 7000 -a password echo "flushall" | redis-cli -p 7001 -a password echo "flushall" |…

docker部署python程序清空redis数据

这里还是要推荐下小编的Python学习群: 823137423,不管你是小白还是大牛,小编我都欢迎 ,不定期分享干货,包括小编自己整理的一份2019年最新的Python资料和0基础入门教程视频,欢迎初学和进阶中的小伙伴。在不忙的时间我会给大家解惑。 docker部署python程序清空redis数据 线…

Windows 清空Redis数据

1.redis安装目录下输入cmd 2.redis-cli -p 端口号 3.flushdb 清除当前数据库缓存 4.flushall 清除整个redis所有缓存

Laravel 清空 Redis 队列

先说问题,我的网站搜索使用的 Laravel Scout Algolia 因为 Algolia 是收费的,免费版有容量限制。免费版应该是如下的限制: 一旦你的 计划超出配额,那么 Laravel 队列就会一直失败。失败他会重试导致 ,队列一直累加、…

教你Redis 如何清空所有数据

这篇文章主要介绍了Redis 如何清空所有数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教 Redis 清空所有数据步骤总结 1、打开cmd 命令窗口,切换至Redis 安装目录下的bin文件夹 2、在cmd 命…

lnx的导数证明

https://zhidao.baidu.com/question/524121644.html