-3

大家好,我只是想帮助理解我理解按位异或和 % 运算符的算法,但我无法理解到底发生了什么我不想要标志我想要underatand 怎么做才能得到标志&谢谢

PASS = input('Enter the Flag: ')
KEY = 'I know, you love decrypting Byte Code !'
I = 5
SOLUCE = [57, 73, 79, 16, 18, 26, 74, 50, 13, 38, 13, 79, 86, 86, 87]
KEYOUT = []
for X in PASS:
    KEYOUT.append((ord(X) + I ^ ord(KEY[I])) % 255)
    I = (I + 1) % len(KEY)

if SOLUCE == KEYOUT:
    print('You Win')
else:
    print('Try Again !')

任何帮助!

4

1 回答 1

0

会有我如何思考这个问题和完整的解决方案。

  1. 注意len(KEYOUT) == len(PASS) == len(SOLUCE)
  2. 请注意,符号之间没有依赖关系
  3. 所以你所需要的就是找到X等于(ord(X) + I ^ ord(KEY[I])) % 255)相应元素的SOLUCE

    FLAG = []
    for part in SOLUCE:
        for ord_X in range(0, 256):
            current_try = (ord_X + I ^ ord(KEY[I])) % 255
            if current_try == part:
                FLAG.append(chr(ord_X))
                break
        else:
            print("fiasco")  # if you aren't sure task is solvable. Not necessary line
        I = (I + 1) % len(KEY)
    

验证是微不足道的。

于 2018-04-05T17:31:21.227 回答