コード例 #1
0
ファイル: challenge06.py プロジェクト: benstannard/cryptopals
def break_repeating_key_XOR(x, k):
    blocks = [x[i:i+k] for i in range(0, len(x), k)]
    transposed_blocks = list(itertools.zip_longest(*blocks, fillvalue=0))
    key = [break_single_byte_XOR(bytes(x))[0] for x in transposed_blocks]
    return bytes(key)
コード例 #2
0
ファイル: challenge04.py プロジェクト: benstannard/cryptopals
def f(filename=None):
    decoded_lines = [binascii.unhexlify(lines.strip()) for lines in open(filename).readlines()]
    best_text = [break_single_byte_XOR(i)[1] for i in decoded_lines] # index tuple
    return max(best_text, key=score)