密码学系列之:生日攻击

简介

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

生日问题的由来

生日问题也叫做生日悖论,它是这样这样描述的。

假如随机选择n个人,那么这个n个人中有两个人的生日相同的概率是多少。如果要想概率是100%,那么只需要选择367个人就够了。因为只有366个生日日期(包括2月29日)。

如果想要概率达到99.9% ,那么只需要70个人就够了。50%的概率只需要23个人。

对于现在的幼儿园小朋友来说,一个班上差不多有30人,那么将会有大于50%的几率,班上有两个人的生日是一样的。

听起来是不是很神奇?跟我们第一映像中的基数是不是要少很多。

我们看一张概率图:

在实际应用中,可以应用生日问题中的概率模型,从而减少碰撞攻击的复杂度,或者来评估一个hash函数中可能出现碰撞攻击的几率。

怎么计算呢?

假如P(A) 是生日相同的概率,那么P(A) = 1 - P(A’) ,其中P(A’)是生日不同的概率。

一个人生日不同的概率是365/365,两个人生日不同的概率就是365/365 * 364/365 ,依次类推。

我们可以得到23个人生日不同的概率大概就是 0.492703。

也就是说23个人中有两个人生日相同的概率可以大于50%。

再看一张表来个更加直观的描述:

生日问题的衍生

生日问题的取值范围是在一年的365天之内,也就是说生日只可能有365种可能性。

我们将这个问题扩展一下到一般的情况,假设有一个函数f,它的输出范围是H,那么我们的攻击就是找到两个不同的x,y,让f(x)=f(y)。

这时候,我们可以称x和y发生了碰撞。

根据概率论的公式,我们想要达到50%的几率,那么需要尝试的次数是:

如果以bits位来表示可能计算出的结果的话,我们可以参考下面的概率表:

生日攻击的应用

生日攻击一般应用在数字签名中。一般来说为了对机密消息进行签名,因为加密的限制,如果消息很大的情况下,不可能对所有的消息进行签名,通常会对消息计算hash值,然后对这个hash值进行签名。

比如有人想做一个欺诈性的合同,那么会在原合同的基础上进行修改,不断的进行尝试,从而找到一个修改后的合同,让合同和之前合同的hash是一样的,从而导致两者的签名也是一样的。

怎么抵御这种攻击呢?根据我们生日攻击的公式,当然是将签名方案使用的哈希函数的输出长度选择得足够大,以使生日攻击在计算上变得不可行。

本文已收录于 http://www.flydean.com/birthday-attack/

最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!

欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!

  • 10
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: 密码学是研究如何保护信息安全的学科,主要包括加密算法和解密算法的设计与实现。C/C++语言是一种被广泛应用于密码学领域的编程语言,其提供了丰富的库函数和数据类型,方便实现各种密码学算法。 在密码学中,加密算法是用于将明文转换为密文的算法,而解密算法则是用于将密文转换回明文的算法。C/C++语言的灵活性和高效性使其成为实现这些算法的理想选择。 在C/C++语言中,可以使用各种库函数来实现密码学算法。例如,可以使用OpenSSL库函数来实现各种对称加密算法(如AES、DES)和非对称加密算法(如RSA、DSA)。这些库函数提供了一系列接口,可以方便地进行密钥生成、加密和解密操作。 此外,C/C++语言还提供了丰富的数据类型和运算操作,可以方便地进行数据处理和运算。例如,可以使用位运算来实现一些常见的密码学操作,如异或操作和循环左移操作。同时,C/C++语言还提供了高效的数据结构,如数组和指针,可以方便地进行数据存储和访问。 总之,C/C++语言在密码学中的应用广泛且灵活。通过使用C/C++语言,可以方便地实现各种加密算法和解密算法,并保护信息的安全。但是在使用C/C++语言实现密码学算法时,需要注意安全性和效率的问题,避免出现漏洞和性能问题。 ### 回答2: 密码学是一门关于保护信息安全的学科,它研究如何设计密码算法以及如何使用密码算法来加密和解密信息。C/C++是一种广泛使用的编程语言,它具有快速、高效的特点,非常适合用来实现密码学算法。 在密码学中,常用的算法有对称加密算法和非对称加密算法。对称加密算法使用同一个密钥来进行加密和解密,而非对称加密算法使用一对密钥,其中一个用于加密,另一个用于解密。 在C/C++中,我们可以使用库函数来实现密码学算法。例如,在对称加密算法中,可以使用openssl库中的函数来实现AES、DES等算法。这些函数提供了加密和解密的接口,我们只需要调用相应的函数,并传入待加密的明文和密钥参数即可实现加密和解密过程。 对于非对称加密算法,我们可以使用openssl库中的函数来实现RSA算法。这些函数提供了生成密钥对、公钥加密、私钥解密的功能,我们可以使用这些函数来实现基于RSA的加密和解密操作。 除了使用库函数外,我们还可以自己编写密码学算法的实现。C/C++具有丰富的数据类型和数据结构,我们可以利用这些特性来实现不同的密码学算法,例如SHA-256哈希算法、AES加密算法等。只需要按照算法的规则进行编码,进行相关的运算和操作即可实现密码学算法。 总之,C/C++语言可以很方便地实现密码学算法,无论是使用库函数还是自己编写算法的实现,都可以利用C/C++的特性和功能来保护信息的安全。 ### 回答3: 密码学是一项研究如何保护通信安全和数据保密性的学科。在密码学中,密钥起着至关重要的作用,因为正确的密钥是保护数据的关键。C/C++语言是一种广泛应用于软件开发的编程语言,可以实现各种密码学算法和协议。 在密码学中,常用的算法有对称加密算法和非对称加密算法。对称加密算法使用相同的密钥进行加密和解密,如AES和DES算法。我们可以使用C/C++语言实现这些算法,通过调用相应的函数来加密和解密数据。这需要理解算法的原理和加密过程,以及相关的库函数和语法。 非对称加密算法使用一对公私钥进行加密和解密,如RSA算法。在C/C++中,可以使用相关库函数来生成密钥对、加密和解密数据。这种加密算法更加安全,但由于复杂性和计算开销较大,通常只用于加密较短的数据或者用于对称密钥的安全传输。 除了加密算法,C/C++语言还可以实现密码学中的其他功能,如哈希函数和数字签名。哈希函数用于将任意长度的数据转化为固定长度的哈希值,常用的算法有MD5和SHA。数字签名用于验证数据的完整性和真实性,通过私钥对数据进行签名,再通过公钥进行验证。 总之,C/C++语言可以通过实现密码学算法和相关功能来保护通信安全和数据保密性。为了确保安全性,需要深入理解密码学的原理和算法设计,同时注意使用安全的库函数和保护密钥的安全存储。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

flydean程序那些事

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值