주어진 암호문은 다음과 같다.
이진수를 그냥 문자열로 바꿔보면 의미 없는 값이 나온다. 문제에서 good_luck이라는 값을 주고 있어서 이걸로 xor해보면 base64 값이 나온다. 근데 이걸 또 base64 디코딩해보면 의미 없는 값이 나오는데 base64 인코딩 값을 카이사르로 전수 조사해 base64 디코딩 해보면 플래그가 나온다.
solve.py
enc_data = """00100011 00100010 00000100 00000010 00001000 00101010
00010111 00001011 00000001 01010101 01010110 00001100
00100010 01101100 00011000 00010001 00001111 00101111
01011110 00011111 00000100 00010001 00011011 00000010
00011001 00101100 00011011 00010011 00101001 01011101
00110010 00111000 00000001 00110011 00101001 01011011
00001101 01011110 01010110 00000110 00011000 00101010
00100011 01010011 00100011 00100001 00111101 01010110""".replace("\n"," ").split(" ")
key = "good_luck"
dec_data = ""
result = ""
for i in enc_data:
dec_data += chr(int(i,2))
for i in range(0,len(dec_data)):
result += chr(ord(dec_data[i])^ord(key[i%len(key)]))
for j in range(26):
caesar_text = ""
for i in result:
if i.isalpha()!=True:
caesar_text += i
else:
if i.isupper():
tmp = ord(i)+j
if tmp>ord('Z'):
tmp -= 26
caesar_text += chr(tmp)
else:
tmp = ord(i) + j
if tmp > ord('z'):
tmp -= 26
caesar_text += chr(tmp)
print caesar_text.decode("base64")
'Crypto & Network & Etc > Crypto Practice' 카테고리의 다른 글
Plaid CTF 2015 Strength (0) | 2019.11.11 |
---|---|
TokyoWesterns CTF 2019 baby_rsa (0) | 2019.11.11 |
KCTF Operation 1 (0) | 2019.11.08 |
HackZone VII 2019 CTF Legacy (0) | 2019.11.08 |
RITSEC CTF 2018 Nobody uses the eggplant emoji (0) | 2019.11.07 |