~$ Dissecting the KnightCTF Reverse Engineering challenges!
Write-ups
Baby Shark (50 points)
During my holiday in Bahamas, I met a baby shark. The shark wanted to sing me something but couldn't. Can you sing that for me?
Flag Format: KCTF{SomE_T3xT_h3r3}
Once the JAR is downloaded, go to javadecompilers.com, and upload it there.
We obtain a ZIP which we then unpack, revealing the following file structure:
data:image/s3,"s3://crabby-images/4bd17/4bd170d4c5a41a05d28e96e80469a691e9c9a798" alt="File tree"
We can see a few interesting Java files, which we'll get into quickly.
The first is Flag.java
, it is not very interesting:
data:image/s3,"s3://crabby-images/70dd3/70dd34b7128ba012852cb4399524d8feedcb948f" alt="A few false flags."
In Strings.java
we can see what resembles strings that are Base64 encoded:
data:image/s3,"s3://crabby-images/6bfcc/6bfcccda0e0107c8a06b1cca690ddb6a772dccc6" alt="The various base64 codes"
If we throw these in a Base64 decoder, the last gives us the flag: KCTF{7H15_W@5_345Y_R16H7?}
Droid Flag (100 points)
One needs to decompile the provided APK, and understand what the decompiled code does, to retrieve the flag.
Once the ZIP is downloaded, extract the APK contained within, then go to javadecompilers.com, and upload it there.
We obtain a ZIP which we then unpack, revealing the following file structure:
data:image/s3,"s3://crabby-images/4a40d/4a40d907d151da27fdea262704402e7fa3d9bc49" alt="The various base64 codes"
We can see a few interesting Java files, which we'll get into quickly.
The first is MainActivity.java
, it contains a few interesting lines:
data:image/s3,"s3://crabby-images/80062/8006286d632c2478d9a1def3c4e79100c5c76944" alt="The various base64 codes"
We can see that this code calls a number of functions in the StringHandler
class from the StringHandler.java
file, in the following order:
$(S1){$(S3)_$(S2)_$(S4)}
data:image/s3,"s3://crabby-images/5c0b3/5c0b3413983260f2adaeb0be2ddc00b498f5a9df" alt="The various base64 codes"
S1
gets a value defined in classC074SR
where the identifier isf112s5
S2
gets a value defined in classC074SR
where the identifier isf113s6
S3
gets a value defined in classC074SR
where the identifier isf114s7
S4
gets a value defined in classC074SR
where the identifier isf115s8
Those values are:
data:image/s3,"s3://crabby-images/c9ffa/c9ffa77b46ee3f514203b6d74dc118db825ebf94" alt="The various base64 codes"
We look for any identifier with those numbers (grep
is useful), and find some in public.xml
:
data:image/s3,"s3://crabby-images/93211/932113a7e7b76bcce7098500a1f098c298cda06f" alt="The various base64 codes"
We then look for the names provided in strings.xml
:
data:image/s3,"s3://crabby-images/ca6e6/ca6e6f5ba08654e9a33b182911d5c1df92e7b9a2" alt="The various base64 codes"
In StringHandler.java
we see that the values for S2
, S3
and S4
are then reversed, which makes the final flag: $(S1){$(S3)_$(S2)_$(S4)}
-> KCTF{aNdR01D_s1MpL3_r3V3rS3}
.