Engineering CTF Competition|Design Engaging Challenges & Setup Efficiently
Discover how engineering teams can create captivating Capture The Flag competitions by efficiently building platforms and designing innovative challenges that boost participant engagement and learning outcomes.
点击这里查看本文章简体中文版本。
點擊這裡查看本文章正體中文版本。
This post was translated with AI assistance — let me know if anything sounds off!
How to Create an Engaging Engineering CTF Competition
Capture The Flag Competition Setup and Challenge Ideas
About CTF
Capture The Flag, abbreviated as CTF, is a sport originating from the West. It is commonly seen in modern paintball and first-person shooter games. The original concept involves teams protecting their own flags from being captured while trying to capture the flags of other teams. In the computer field, it refers to “offensive and defensive hacking battles,” where teams first find and protect their own vulnerabilities from intrusion, while simultaneously launching zero-delay attacks to capture points from other teams.
The above represents a standard, or even “advanced,” CTF competition format. Running a CTF competition within a company involves additional practical considerations:
The purpose of hosting a CTF competition, besides enhancing technical skills, is also to promote communication among engineers.
Engineers have different specialties, including Front-End, Back-End, APP, and DevOps; if you want everyone to participate, the questions should not focus too much on a specific field (e.g., networking, PHP).
Groups should balance strengths and evenly distribute domain expertise.
The event lasts at most one afternoon.
Organizing a CTF competition is a side project outside of the main work duties, with limited resources and time.
Considering all the above factors, rather than calling it a CTF competition, it is more like a:
Group Puzzle Solving to Earn Flag Points & Promote Interaction Among Engineers
A beginner-level CTF competition!
Event Objectives
Enhancing Engineering Skills
Promoting communication among engineers
Inspiring everyone’s passion and keen insight for exploration
Interesting things are fun; boring things are painful to do.
3 and 4 are my own additions. My expectations for this event go beyond practical aspects; I hope to boost everyone’s passion for exploring and learning new things in a fun way. Just like in daily work, we shouldn’t just be coders; we need to find ways to break through and keep moving forward!
Competition Rules
Divide engineers into groups evenly based on their expertise and strengths.
Competition Time: 90 minutes
There are a total of 12 questions, with 3 chances to spend points to buy hints.
Purchase cost decreases over time (the earlier you buy, the more expensive it is)
Each question has a base score plus a time bonus (the earlier you solve, the more points you get)
Once you start answering a specific question, you will be locked to only answer that question or other already opened questions; this continues until the question is passed or the lock time ends.
(This rule exists because the activity mainly aims to encourage team members to communicate and brainstorm together, rather than dividing the work.)The score per question, hint cost, and lock time vary according to the difficulty of the question.
Victory Condition: The highest cumulative score wins. If scores are tied, the faster completion time determines the winner.
The winning team has $$
How to Build?
After clarifying the event rules and objectives, the next key point is how to win a CTF competition?
This section is divided into two chapters: First, building a system capable of hosting CTF competitions, and Second, brainstorming competition challenges.
1. Building a System Capable of Hosting CTF Competitions
This part requires both front-end and back-end skills to implement. If you are not familiar, you will need to ask other colleagues for help.
Frontend: Semantic UI
Backend: PHP + JSON file for data storage
Due to limited time, the competition system was built with simplicity, stability, and speed in mind. The front-end interface directly uses the Semantic UI framework. The back-end is written in PHP without any framework. Data storage is handled using JSON files without a database. Keeping everything simple also reduces potential issues (such as someone trying to hack the system to get the answers).
Entry Page:
Starting with fun, the landing page uses references from the BBC series Sherlock:
Phone Unlock Password S H E R
These four input boxes are for entering the identification codes (4 digits) obtained by each group. For example, enter the first group: “1432”, the second group: “8421”, to identify which group will answer the questions.
As for the identification codes for each group, I added a little twist. The codes are displayed as follows:
Can you see the four-digit code? If not, please step back from the screen and take another look.
請提供您需要翻譯的 Markdown 文章段落內容。
請提供您要翻譯的 Markdown 文章段落內容,我將依照您的要求進行翻譯。
請提供您想翻譯的 Markdown 文章段落內容,我會幫您進行翻譯。
………………………
Please provide the Markdown paragraphs you want me to translate into English.
………………………………….
……………………………. .
……………………….
………………. .
請提供您要翻譯的 Markdown 段落內容,我將依據您的要求進行翻譯。
請提供您需要翻譯的 Markdown 文章內容。
. .
Answer: The ID for the first group is 8291
After entering, you will go to the competition system homepage - problem list:
Displayed above: Team 1 group, remaining number of hint tickets
Middle Question Area: Question title, description, passing score, lock time, purchase hint, hint display
Mouse hover will display time score and suggested price
Displayed below: Total current score
Backend and Other Logic: The question list page uses Ajax every second to request the current answering status from the backend. The backend reads and records the answering status in each group’s JSON file. When unlocking a question, the time is recorded; questions cannot be unlocked before the set time. Upon passing a question, the completion time is recorded. Time scores and hint prices increase or decrease based on the time spent.
The competition system is roughly like this, but the focus is not on the system itself, but on the questions!
Is it interesting, can everyone participate, is it logical, is it novel… it’s really hard to come up with ideas
Let’s get straight to the point!
2. Competition Topic Ideation
First, I will introduce the five topics I have come up with.
1. The Gate to the Magic Academy
Problem Description: You will receive a key string. Use this key to decode the spell and enter it in the spell input box. Below, there is a captcha field that needs to be filled in. Press verify to submit your answer.
Answer:
This question tests cybersecurity and coding issues; it involves platform encryption and decryption vulnerability interfaces. If a website uses the same method and key for all encryption and decryption, we can exploit this weakness to decrypt the content and obtain the original data!
You can see the captcha part is ./image.php?token=AD0HbwdgVDw=
. Here, a decryption interface is provided, so we can try using the above encryption key:
You will get the decrypted string: LiveALifeYouWillRemeber
Enter it into the spell input box to clear the level!
2. Please take me back to Shanghai in 1937!
Problem Description: You need to find a way to input year/month/day and submit it to the backend so that the backend recognizes the year as 1937; the input year range (1947~2099) does not allow directly entering 1937.
Answer:
This question is not about bypassing front-end validation, as the back-end handles it and cannot be bypassed. The main focus is on the 32-bit computer Year 2038 problem. Due to the 32-bit limit, the timestamp can only represent dates up to January 19, 2038, 03:14:07. Beyond this, it will overflow and reset to January 1, 1901. Therefore, by inputting dates from 2073–02–06 to 2074–02–05
, the system will interpret them as dates in 1937. Entering dates within this range will allow successful submission!
3. The Duel of Wits
Problem Description: Find a way to intercept a password reset email sent to a third party’s email account (which you cannot log into) and complete the password reset for that person.
Answer:
This task requires more sensitivity. First, use an email account you can access to reset the password; the email we received is as follows:
1
Your password reset link: http://ctf.zhgchg.li/10/reset.php?requestid=OTk= If this is not related to you, please ignore this message. Thank you!
We can see that the password reset request is identified through the parameter requestid. The value we got is OTk=
, which looks like base64? Let’s try it:
We can get the parameter value as 99, then repeat the password reset request to get 100. Therefore, it can be inferred that the password reset requests are sequential numbers, with the next being 101. At this point, returning to the original email to bypass and pressing the reset password request, we can forge and combine the password reset link ourselves, thus secretly resetting someone else’s password.
Encode 101 in Base64 => MTAx. Fake URL: http://ctf.zhgchg.li/10/reset.php?requestid=MTAx
. Enter any password and click reset to pass!
4. Vest Master
Task Description: You need to create 10 sets of Gmail accounts (Gmail hosted mailboxes) to receive answer emails.
Answer:
Of course, this problem can be brute-forced, but company email accounts cannot be registered casually; unless you find 10 people to help receive emails, it cannot be solved.
The key point here is the Gmail mailbox / Gmail hosted mailbox. Since the company mailbox is a Gmail hosted mailbox, it also has the features of a Gmail mailbox: you can use “.” and “+” to create unlimited alias addresses. The “.” can be placed anywhere in the username, and the “+” can be placed at the end followed by any numbers.
For example: The main mailbox is zhgchgli@gmail.com
, but emails sent to z.hgchgli@gmail.com, zh.gchgli@gmail, zhgchgli+1@gmail.com, zhgchgli+25@gmail.com, and so on will all be delivered to the main mailbox zhgchgli@gmail.com
. One mailbox can create multiple identities!
This article mainly reminds everyone to filter out these characters during account registration to prevent malicious users from creating大量fake accounts.
After collecting 10 letters, you can assemble the URL containing the answer. Enter the URL to clear the level!
5. Time Machine
Problem Description: Similar to question 3 “Face/Off,” you need to find a way to intercept a third party’s (you cannot receive their SMS) mobile SMS verification code (4-digit number) to log into someone else’s account.
Answer:
This problem is relatively obscure and difficult, mainly simulating a side-channel timing attack. The system login verification involves a complex algorithm, and there is a time difference when processing verification information (for example: processing one correct digit takes longer, while a completely wrong input returns immediately and quickly). By observing these time differences, we start from 0000
and try each digit one by one. When trying 2000
, we notice it takes one second to process, indicating the first digit is 2
. Continuing with 2100
, it still takes one second, but 2200
takes even longer—two seconds. By further testing the third and fourth digits, we eventually obtain the correct answer: 2256
.
This example only simulates this type of attack. The backend processing uses sleep to mimic the delay without actual complex algorithms. Such attacks are rarely encountered in web or app environments. On one hand, the processing is not complex enough to cause noticeable time differences; on the other hand, network factors also affect timing, making it difficult to judge.
For detailed information about side-channel attacks, please refer to this article:
](/assets/729d7b6817a4/1*SF1S_RZNTI-5ZaC3Kw1Ypw.webp){: lqip=”” }
Understand CORB in 30 Minutes — Side-Channel Attacks
The above are the 5 questions I came up with. Below are the remaining 7 questions provided by my colleagues.
1. Sadako Appearance
Sadako image sourced from the internet
Problem Description: The problem is an image of Sadako. You need to enter what Sadako wants to say in the input box above to pass.
Answer:
This question tests whether you know that images can contain other information. The key lies in the original version of this image:
Sadako image sourced from the internet
This image has secretly compressed a text file inside it (for the actual method, please refer to: How To Hide A ZIP File Inside An Image On Mac [Quicktip] , note the Win/Mac compatibility issues here)
So we only need to simply unzip the Commone image to get the passcode string:
Enter “YOUHAVENOIDEA” in the input box to pass!
Supplement:
Regarding hidden information in images, there is another method using “Image Steganography”.
Image Steganography and Malware: Principles and Methods
Simply put, it manipulates the pixel color values to hide information. The actual image changes, but the difference is invisible to the naked eye.
I was worried everyone would take this approach, so I hid a code in the image. Those who follow this path can get a hint:
Upload the image to an online steganography decoding tool to get the hint.
2. Caesar’s Morse Code
The images are sourced from the internet.
Problem Description: Decode the given Morse code to find the hidden message (an English sentence).
Answer:
This question is quite straightforward. The first step is to decode the Morse code into the English letters “VYYXI DN HT GDAZ”.
Then perform a Caesar cipher decryption. When we try a shift of 5, we get a meaningful English sentence: “addcn is my life,” which is the answer!
3. What do you think it is?
Opening the webpage for this question shows a lot of garbled text, as follows:
1
...
Problem Description: Find the answer from this jumble of characters.
Answer:
This question is actually quite straightforward and doesn’t require much thought; frequent coders should recognize this jumble as a base64 string. Let’s first decode it, and we get:
1

From the beginning, it is clear that this is a base64 compressed image. By pasting the above code directly into the browser’s address bar, you can get the URL with the answer. Enter the URL to pass the challenge!
4. Breaking Through the Blockade
Problem Description: This problem immediately shows the PHP code. You need to find a way to bypass the condition using GET parameters to execute the setPassedCookie() method inside the else block.
Solution: This is a commonly used but little-known PHP vulnerability, detailed as follows:
Summary of Common PHP Vulnerabilities in CTF
The question has been slightly modified. The answer to this question is: ?m.id[ ]=admin
5. The Test of Penetration, 6. The Test of Penetration 2
These two questions are basic introductory XSS problems, so no further explanation will be given here.
Since the solution is placed on the frontend, this uses a JS website that provides irreversible encryption: https://www.sojson.com/jsobfuscator.html
(Although I’m not sure if it’s true, if there’s a way to crack it, let’s just consider it passed!)
7. Moonlight Treasure Box
This question is taken from a puzzle app and will not be shown here.
Summary
The competition system took about a week to build, and the questions took around three months to gradually gather (inspiration was needed). The competition has successfully concluded, and the feedback has been quite positive—”fun and enjoyable.” This was my original intention: to have everyone explore and brainstorm starting from a point of fun. Therefore, neither the question titles (which are all very cinematic) nor the question directions involve deep engineering or complex calculations, as that would be too rigid and not fun!
Additionally, here is the question response rate for reference on difficulty:
When creating the questions, the biggest fear was that they would be too easy and everyone would finish quickly, or too hard and everyone would get stuck. Both situations are awkward.
The actual competition results (duration: 90 minutes) matched our expectations perfectly! It was neither too hard nor too easy. The first-place team solved 9 problems, while even the last-place team solved 7 problems. The scores were very close, but factors like time and hint purchases ultimately determined the final rankings!
Surprisingly, no one has solved the entrance to the Magic Academy… QQ
The above is the complete summary of this engineering CTF competition.
Addcn 2019 CTF
Further Reading
Revealing a Clever Website Vulnerability Discovered a Few Years Ago
The app uses HTTPS for transmission, but data was still stolen
If you have any questions or feedback, feel free to contact me.
This post was originally published on Medium (View original post), and automatically converted and synced by ZMediumToMarkdown.