Description
The challenge exposes a PostgreSQL instance with a single table called flags. Connect with psql, list the relations, and dump the flag.
Setup
Connect using the supplied command: psql -h saturn.picoctf.net -p 51070 -U postgres pico (password postgres).
List the tables with \dt and note the flags table.
Select everything from the table, then verify the output matches picoCTF{...} before submitting.
psql -h saturn.picoctf.net -p 51070 -U postgres pico\dtSELECT * FROM flags;\copy flags TO flag.csv CSVgrep -oE 'picoCTF\{[^}]+\}' flag.csvSolution
Walk me through itpsql access with default credentials, so this is one SELECT away from the flag. If the connection rejects you with psql: error: connection to server ... password authentication failed, the credentials in the challenge prompt have been re-issued; reconnect with the new ones rather than guessing. The SQL Injection for CTF guide covers the actual injection cases (auth bypass, UNION, blind SQLi, sqlmap) for the picoCTF challenges that need them.- Step 1Enumerate relations
\dtlists the available tables (onlyflags). The column of interest contains the picoCTF value.Learn more
psql is the official command-line client for PostgreSQL, one of the most widely used open-source relational databases. It supports both standard SQL and meta-commands (prefixed with
\) that are specific to psql.\dtlists all tables (relations) in the current database;\d tablenameshows a table's schema;\llists all databases.In this challenge, the database is intentionally exposed with default credentials (
postgres/postgres) - a critical misconfiguration seen in real-world environments. Default credentials on database servers are a top finding in penetration tests. Tools like Metasploit'spostgres_loginscanner and hydra automate credential testing against exposed database ports.PostgreSQL runs on port 5432 by default. During network recon, port scans with nmap flag open database ports, which are then probed for default or weak credentials. Once inside,
information_schema.tables(standard SQL) or\dt(psql-specific) quickly reveals the database structure. - Step 2Dump the flagEither run
TABLE flags;directly in psql or copy the table to a CSV and parse it locally with grep/cut.Learn more
SELECT * FROM flags;is the most basic SQL query - it retrieves every row and column from the table.TABLE flags;is a PostgreSQL shorthand for the same thing. For larger tables, addLIMIT 10to preview the first 10 rows, orWHERE column LIKE '%picoCTF%'to filter.The
\copymeta-command exports query results to a local file (running client-side). This is distinct fromCOPY(no backslash), which runs server-side and requires superuser privileges to write to the server filesystem. Both support CSV, binary, and tab-delimited formats.In real incident response or data exfiltration scenarios, attackers with database access commonly use
SELECTto extract entire tables,pg_dumpto export the full database, orCOPY TOto write files to the server. Defense-in-depth means: don't expose database ports to the internet, use strong unique credentials, enable SSL, restrict user privileges with least privilege, and audit all connections via database logs.
Flag
picoCTF{L3arN_S0m3_5qL_t0d4Y_31fd...}
PostgreSQL’s meta-commands (`\dt`, `\copy`, etc.) make exploratory tasks like this very quick.