-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathxor4.py
54 lines (42 loc) · 2.26 KB
/
xor4.py
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
import binascii
# Encrypted data in hexadecimal format
encrypted_data_hex = "cfac ef32 574f 205e e1fa bb74 0931 533f fe98".replace(" ", "")
encrypted_data = bytes.fromhex(encrypted_data_hex)
try:
# Step 1: Extract Version and Flag Length
version_number = encrypted_data[0] # First byte
flag_length_bytes = encrypted_data[1:5] # Next four bytes (big-endian)
flag_length = int.from_bytes(flag_length_bytes, byteorder='big')
# Ensure we have enough data for the flag
if 5 + flag_length > len(encrypted_data):
raise ValueError("Flag length exceeds available encrypted data.")
# Step 2: Extract Encrypted Flag Data
encrypted_flag_data = encrypted_data[5:5 + flag_length]
# Step 3: Known Prefix (adjusted to a length of 3 bytes)
known_prefix = b"SKY"
# Step 4: Deduce XOR Key using Known Prefix
xor_key = bytes([encrypted_flag_data[i] ^ known_prefix[i] for i in range(len(known_prefix))])
# Step 5: Expand XOR Key to Full Length of Encrypted Flag Data
xor_key_length = 8 # We know the key is 8 bytes
full_xor_key = (xor_key * (len(encrypted_flag_data) // xor_key_length)) + xor_key[:len(encrypted_flag_data) % xor_key_length]
# Step 6: Decrypt Flag
decrypted_flag = bytes([encrypted_flag_data[i] ^ full_xor_key[i] for i in range(len(encrypted_flag_data))])
# Results
first_byte_of_xor_key = hex(xor_key[0]) # Q1: First byte of XOR key
full_xor_key_hex = binascii.hexlify(full_xor_key).decode() # Q2: Full XOR key in hex
# Attempt to decode the decrypted flag with error handling
try:
plaintext_flag = decrypted_flag.decode('utf-8') # Primary attempt with utf-8
except UnicodeDecodeError:
plaintext_flag = decrypted_flag.decode('latin-1') # Fallback to latin-1 if utf-8 fails
print("Q1 - First byte of XOR key:", first_byte_of_xor_key)
print("Q2 - Full XOR key (hex):", full_xor_key_hex)
print("Q3 - Plaintext Flag:", plaintext_flag)
except ValueError as ve:
print("Error:", ve)
except IndexError:
print("Error: Encrypted data is too short or flag length exceeds available data.")
except UnicodeDecodeError:
print("Error: Unable to decode the decrypted flag, even with fallback encoding.")
except Exception as e:
print(f"An unexpected error occurred: {e}")