Set 1-6 Break repeating-key XOR实现方法

该博客介绍了如何破解使用repeating-key XOR加密并经过base64编码的密文。通过猜测密钥长度,计算Hamming distance,将密文分块,并使用single-character XOR处理,最终找到最高评分的明文文本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Set 1-6 Break repeating-key XOR

题目来源:
https://cryptopals.com/sets/1/challenges/6

题目大意

使用repeating-key XOR对明文文本进行加密并进行base64编码得到此文件,试得到明文文本。

分析

  1. 首先猜测密钥长度,记为keysize,建议猜测范围为2到40。
  2. 写一个计算两个字符串的Hamming distance的函数。Hamming distance是两个字符串不同比特的数量。例如,this is a testwokka wokka!!!之间的Hamming distance为37。
  3. 对于每一个keysize,获得密文文本的第一个长度为keysize的块以及第二个长度为keysize的块,计算这两个块的Hamming distance并除以keysize得到结果记为nomal_distance。
  4. 有着最小的nomal_distance的keysize很可能就是密钥的长度。可以选择最小的三个nomal_distance所对应的keysize进行接下来的操作。也可以在第3步中使用4个keysize大小的块来计算得到nomal_distance。
  5. 将密文分为长度为keysize的块。
  6. 将每个块中的第一个字节组合成一个新的块,每个块中的第二个字节组合成一个新的块,依次类推。
  7. 使用single-character XOR来处理每个新块。即第一个新块中的每个字节均和密钥的第一个字节异或,第二个新块中的每个字节均和密钥的第二个字节异或,依次类推。由此可得到每个keysize所对应的候选密钥key。
  8. 分别将每个候选密钥key与密文进行xor_repeat_key操作得到明文文本。计算各个明文文本的评分分数,分数最高的即为我们需要得到的明文文本。

实现

python代码见github:
https://github.com/nasume/cryptopals/blob/master/Set1/break_repeating_key_XOR.py

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值