The Metasploit Project is a computer security project that provides information about security vulnerabilities and aids in penetration testing and IDS signature development. It is owned by Boston, Massachusetts-based security company, Rapid7.
Original author(s) | H. D. Moore |
---|---|
Developer(s) | Rapid7, Inc. |
Initial release | 2003[1] |
Stable release | 6.3.36[2]
/ September 28, 2023 |
Repository | github |
Written in | Ruby |
Operating system | Cross-platform |
Type | Security |
License | Framework: BSD,[3] Community/Express/Pro: Proprietary |
Website | www |
Its best-known sub-project is the open-source[3] Metasploit Framework, a tool for developing and executing exploit code against a remote _target machine. Other important sub-projects include the Opcode Database, shellcode archive and related research.
The Metasploit Project includes anti-forensic and evasion tools, some of which are built into the Metasploit Framework. In various operating systems it comes pre installed.
History
editMetasploit was created by H. D. Moore in 2003 as a portable network tool using Perl. By 2007, the Metasploit Framework had been completely rewritten in Ruby. On October 21, 2009, the Metasploit Project announced[4] that it had been acquired by Rapid7, a security company that provides unified vulnerability management solutions.
Like comparable commercial products such as Immunity's Canvas or Core Security Technologies' Core Impact, Metasploit can be used to test the vulnerability of computer systems or to break into remote systems. Like many information security tools, Metasploit can be used for both legitimate and unauthorized activities. Since the acquisition of the Metasploit Framework, Rapid7 has added an open core proprietary edition called Metasploit Pro.[5]
Metasploit's emerging position as the de facto exploit development framework[6] led to the release of software vulnerability advisories often accompanied[7] by a third party Metasploit exploit module that highlights the exploitability, risk and remediation of that particular bug.[8][9] Metasploit 3.0 began to include fuzzing tools, used to discover software vulnerabilities, rather than just exploits for known bugs. This avenue can be seen with the integration of the lorcon wireless (802.11) toolset into Metasploit 3.0 in November 2006.
Framework
editThe basic steps for exploiting a system using the Framework include.
- Optionally checking whether the intended _target system is vulnerable to an exploit.
- Choosing and configuring an exploit (code that enters a _target system by taking advantage of one of its bugs; about 900 different exploits for Windows, Unix/Linux and macOS systems are included).
- Choosing and configuring a payload (code that will be executed on the _target system upon successful entry; for instance, a remote shell or a VNC server). Metasploit often recommends a payload that should work.
- Choosing the encoding technique so that hexadecimal opcodes known as "bad characters" are removed from the payload, these characters will cause the exploit to fail.
- Executing the exploit.
This modular approach – allowing the combination of any exploit with any payload – is the major advantage of the Framework. It facilitates the tasks of attackers, exploit writers and payload writers.
Metasploit runs on Unix (including Linux and macOS) and on Windows. The Metasploit Framework can be extended to use add-ons in multiple languages.
To choose an exploit and payload, some information about the _target system is needed, such as operating system version and installed network services. This information can be gleaned with port scanning and TCP/IP stack fingerprinting tools such as Nmap. Vulnerability scanners such as Nessus, and OpenVAS can detect _target system vulnerabilities. Metasploit can import vulnerability scanner data and compare the identified vulnerabilities to existing exploit modules for accurate exploitation.[10]
Interfaces
editThere are several interfaces for Metasploit available. The most popular are maintained by Rapid7 and Strategic Cyber LLC.[11]
Framework Edition
editThe free version. It contains a command line interface, third-party import, manual exploitation and manual brute forcing. This free version of the Metasploit project also includes Zenmap, a well known security scanner, and a compiler for Ruby, the language in which this version of Metasploit was written.[11]
Pro
editIn October 2010, Rapid7 added Metasploit Pro, an open-core commercial Metasploit edition for penetration testers. Metasploit Pro adds onto Metasploit Express with features such as Quick Start Wizards/MetaModules, building and managing social engineering campaigns, web application testing, an advanced Pro Console, dynamic payloads for anti-virus evasion, integration with Nexpose for ad-hoc vulnerability scans, and VPN pivoting.
Discontinued editions
editCommunity
editThe edition was released in October 2011, and included a free, web-based user interface for Metasploit. Metasploit Community Edition was based on the commercial functionality of the paid-for editions with a reduced set of features, including network discovery, module browsing and manual exploitation. Metasploit Community was included in the main installer.
On July 18, 2019, Rapid7 announced the end-of-sale of Metasploit Community Edition.[12] Existing users were able to continue using it until their license expired.
Express
editThe edition was released in April 2010, and was an open-core commercial edition for security teams who need to verify vulnerabilities. It offers a graphical user interface, It integrated nmap for discovery, and added smart brute-forcing as well as automated evidence collection.
On June 4, 2019, Rapid7 discontinued Metasploit Express Edition.[13]
Armitage
editArmitage is a graphical cyber attack management tool for the Metasploit Project that visualizes _targets and recommends exploits. It is a free and open source network security tool notable for its contributions to red team collaboration allowing for shared sessions, data, and communication through a single Metasploit instance.[14]
The latest release of Armitage was in 2015.
Cobalt Strike
editCobalt Strike is a collection of threat emulation tools provided by HelpSystems to work with the Metasploit Framework.[15] Cobalt Strike includes all features of Armitage and adds post-exploitation tools, in addition to report generation features.[16]
Exploits
editMetasploit currently has over 2074 exploits, organized under the following platforms: AIX, Android, BSD, BSDi, Cisco, Firefox, FreeBSD, HP-UX, Irix, Java, JavaScript, Linux, mainframe, multi (applicable to multiple platforms), NetBSD, NetWare, NodeJS, OpenBSD, macOS, PHP, Python, R, Ruby, Solaris, Unix, and Windows.
Note that Apple iOS is based on FreeBSD, and some FreeBSD exploits may work, while most won't.
Payloads
editMetasploit currently has over 592 payloads. Some of them are:
- Command shell enables users to run collection scripts or run arbitrary commands against the host.
- Meterpreter (the Metasploit Interpreter) enables users to control the screen of a device using VNC and to browse, upload and download files.
- Dynamic payloads enable users to evade anti-virus defense by generating unique payloads.
- Static payloads enable static IP address/port forwarding for communication between the host and the client system.
Auxiliary modules
editThe Metasploit Framework includes hundreds of auxiliary modules that can perform scanning, fuzzing, sniffing, and much more. There are three types of auxiliary modules namely scanners, admin and server modules.
Contributors
editMetasploit Framework operates as an open-source project and accepts contributions from the community through GitHub.com pull requests.[17] Submissions are reviewed by a team consisting of both Rapid7 employees and senior external contributors. The majority of contributions add new modules, such as exploits or scanners.[18]
List of original developers:
- H. D. Moore (founder and chief architect)
- Matt Miller (core developer from 2004–2008)
- Dean McNamee (Spoonm) (core developer from 2003–2008)
See also
editReferences
edit- ^ "A Brief History of Metasploit". Archived from the original on 2023-08-03. Retrieved 2024-05-23.
- ^ "Tags · rapid7/Metasploit-framework". GitHub. Archived from the original on 2022-12-19. Retrieved 2024-05-23.
- ^ a b "3-clause BSD license". GitHub. Archived from the original on 2021-01-30. Retrieved 2013-06-24.
- ^ "Rapid7 Press Release". Rapid7. Archived from the original on 15 July 2011. Retrieved 18 February 2015.
- ^ "Metasploit Editions: Network Pen Testing Tool". Rapid7. Archived from the original on 2023-07-20. Retrieved 2023-08-03.
- ^ "Vulnerability exploitation tools – SecTools Top Network Security Tools". Archived from the original on 17 October 2011. Retrieved 18 February 2015.
- ^ Metasploit. "Metasploit". www.exploit-db.com. Archived from the original on 2017-01-16. Retrieved 2017-01-14.
- ^ "ACSSEC-2005-11-25-0x1 VMWare Workstation 5.5.0 <= build-18007 GSX Server Variants And Others". December 20, 2005. Archived from the original on 2007-01-07.
- ^ "Month of Kernel Bugs – Broadcom Wireless Driver Probe Response SSID Overflow". November 11, 2006. Archived from the original on January 3, 2013.
- ^ "Penetration Testing Tool, Metasploit, Free Download - Rapid7". Rapid7. Archived from the original on 24 December 2017. Retrieved 18 February 2015.
- ^ a b "Metasploit editions". rapid7.com. rapid7. Archived from the original on 10 March 2015. Retrieved 16 February 2013.
- ^ "End of Sale Announced for Metasploit Community". Rapid7 Blog. 2019-07-18. Archived from the original on 2020-07-13. Retrieved 2020-07-13.
- ^ "Announcement: End of Life for Metasploit Express Edition". Rapid7 Blog. 2018-06-04. Archived from the original on 2020-07-16. Retrieved 2020-07-13.
- ^ "Armitage A GUI for Metasploit". Strategic Cyber LLC. Archived from the original on 2016-01-14. Retrieved 2013-11-18.
- ^ "Adversary Simulation and Red Team Operations Software - Cobalt Strike". cobaltstrike.com. Archived from the original on 2019-01-28. Retrieved 2019-01-22.
- ^ "Armitage vs Cobalt Hooked Strike". Strategic Cyber LLC. Archived from the original on 2016-03-19. Retrieved 2013-11-18.
- ^ "rapid7/metasploit-framework". GitHub. Archived from the original on 2018-07-26. Retrieved 2017-01-14.
- ^ "Contributing to Metasploit". Rapid7, Inc. Archived from the original on 2016-09-24. Retrieved 2014-06-09.
Further reading
edit- Powerful payloads: The evolution of exploit frameworks, searchsecurity.com, 2005-10-20
- Chapter 12: Writing Exploits III from Sockets, Shellcode, Porting & Coding: Reverse Engineering Exploits and Tool Coding for Security Professionals by James C. Foster (ISBN 1-59749-005-9). Written by Vincent Liu, chapter 12 explains how to use Metasploit to develop a buffer overflow exploit from scratch.