히공

hackingcamp22CTF - revtine 본문

write up/hackingcamp22CTF

hackingcamp22CTF - revtine

heegong 2021. 3. 20. 19:06
728x90

 

문제

 

 

 

 

 

revtine파일 하나가 있다.

 

 

 

 

 

 

Ch0c0l4te_v3_1, Ch0c0l4te_v3랑 같은 친구다. 왜 두 개로 나뉜 것인지 모르겠다.

 

 

 

 

 

 

 

 

 

 

Ch0c0l4te_v5는 "Ch0c0l4te"로 고정된다.

 

 

 

 

 

 

 

 

저 sub_1000036E0는

 

 

 

 

 

 

 

 

각 요소를 0xA와 xor하는 함수다.

 

 

 

 

 

 

여기서 free 해주는 것을 보아 분석할 필요가 없는 함수라는 것을 알 수 있다.

 

 

 

 

 

 

 

 

여기도 페이크 루틴이 많다.

 

 

 

 

 

 

 

 

여기가 가장 중요하다.

 

 

 

 

 

 

 

sub_1000037F0 함수다.

암호화를 하는 것을 볼 수 있다.

 

 

 

 

 

 

 

 

여기에 인자로 들어가는

off_100008078가 많이 중요하다.

 

 

 

 

 

 

 

 

off_100008078다.

 

 

 

 

 

 

 

 

문자열 중 이러한 문자열이 있다.

해석하면 나의 마음을 반대로 읽을 수 있느냐? 이런 뜻입니다.

여기서 복호화 코드를 만들어야 한단 것을 유추할 수 있습니다.

 

 

 

def unsigned_int_8(num):
    if num<0:
        num+=0x100
    return num

v6= [0x48, 0x5E, 0x76, 0x35, 0x6E, 0x74, 0x5F, 0x74, 0x3D, 0x59, 0x67, 0x75, 0x72, 0x80, 0xE7, 0x03, 0x03, 0x13, 0x0A, 0x11, 0x12, 0x4D, 0x49, 0x45, 0x2F,0]

for i in range(8,14):
    v6[i]-=i-5
    v6[i]^=9
    v6[i]^=3
    
for j in range(14,25):
    v6[j]^=0xc
    v6[j] = unsigned_int_8(v6[j]-10*j)
    
for k in range(4):
    v6[k] ^= 2
    v6[k] ^= 4
    v6[k] ^= 8
    v6[k] ^= 0xF
    v6[k] &= 0xff

v6 = [chr(i) for i in v6]
v6 = ''.join(v6)
print("HCAMP{%s}"%v6)

 

 

플래그 : HCAMP{I_w4nt_t0_hear_youR_Voic3}

'write up > hackingcamp22CTF' 카테고리의 다른 글

hackingcamp22CTF - dvm-rev  (0) 2021.03.20
hackingcamp22CTF - Opps Enc!  (0) 2021.03.20
hackingcamp22CTF - Demon Notepad  (0) 2021.03.20
hackingcamp22CTF - Do u know it?  (0) 2021.03.20
Comments