Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
This repository was archived by the owner on Oct 16, 2023. It is now read-only.

A collection of hacking tools, resources and references to practice ethical hacking.

License

NotificationsYou must be signed in to change notification settings

sundowndev/hacker-roadmap

Repository files navigation

Hacker roadmap


This repository is a overview of what you need to learn penetration testing and a collection of hacking tools, resources and references to practice ethical hacking. Most of the tools are UNIX compatible, free and open source.

Before you start

  • If you're new to information security, forget everything you know about hacking.
  • Don't start using tools without reading about pen testing and how it works (seeAdditional resources section).
  • Don't download and use tools that you don't audited the code.
  • Don't use these tools to do stupid things like investigating/hacking without consent on your friends, or worst, your recruiter.
  • Read books, manuals, articles, be curious and not just ascritpt kiddie.
  • I wish you don't use these tools for illegal purposes, but if you do, I sure hope you know what you do.

Table of Contents

(TOC made withnGitHubTOC)

Introduction

What is penetration testing ?

Penetration testing is a type of security testing that is used to test the insecurity of an application. It is conducted to find the security risk which might be present in the system.

If a system is not secured, then any attacker can disrupt or take authorized access to that system. Security risk is normally an accidental error that occurs while developing and implementing the software. For example, configuration errors, design errors, and software bugs, etc.Learn more

Want to become a penetration tester ?

Know about risks on the internet and how they can be prevented is very useful. Especially as a developer. Web hacking and penetration testing is the v2.0 of self-defense! But does know about tools and how to use them is really all you need to become a pen tester? Surely not. A real penetration tester must be able to proceed rigorously and detect the weaknesses of an application. He must be able to identify the technology behind and test every single door that might be open to hackers.

This repository aim first to establish a reflection method on penetration testing and explain how to proceed to secure an application. And secondly, to regroup all kind of tools or resources pen testers need.Be sure to know basics of programming languages and Internet security before learning pen testing.

Also, this is important to inform yourself about the law and what you are allowed to do or not. According to your country, the computer laws are not the same. First, check laws about privacy and surveillance :Nine eyes countries,Five eyes and Fourteen Eyes. Always check if what you're doing is legal. Even when it's not offensive, information gathering can also be illegal !

(Table of Contents)

Some vocabulary

Infosec : Information security, which is the practice of preventing unauthorized access, use, disclosure, disruption, modification, inspection, recording or destruction of information. The information or data may take any form, e.g. electronic or physical. An infosec can also be a person who practice ethical security.Wikipedia

Opsec : Operations security, which is a process that identifies critical information to determine if friendly actions can be observed by enemy intelligence, determines if information obtained by adversaries could be interpreted to be useful to them, and then executes selected measures that eliminate or reduce adversary exploitation of friendly critical information.Wikipedia

Black/grey/white hat hacker : Someone who uses bugs or exploits to break into systems or applications. The goal and the method differs depending if he's a black, grey or white hat hacker. A black hat is just someone malicious that does not wait permission to break into a system or application. A white hat isusually a security researcher who practice ethical hacking. A grey hat is just in the middle of these two kind of hackers, he might want to be malicious if it can be benefit (data breach, money, whistleblowing ...).

Red team : According to Wikipedia, a red team or the red team is an independent group that challenges an organization to improve its effectiveness by assuming an adversarial role or point of view. It is particularly effective in organizations with strong cultures and fixed ways of approaching problems. The United States intelligence community (military and civilian) has red teams that explore alternative futures and write articles as if they were foreign world leaders. Little formal doctrine or publications about Red Teaming in the military exist. In infosec exercises, Red teamers are playing the role of attackers.Wikipedia

Blue team : A blue team is a group of individuals who perform an analysis of information systems to ensure security, identify security flaws, verify the effectiveness of each security measure, and to make certain all security measures will continue to be effective after implementation. As a result, blue teams were developed to design defensive measures against red team activities. In infosec exercises, Blue teamers are playing the role of defenders.Wikipedia

Penetration tester : An ethical hacker who practice security, test applications and systems to prevent intrusions or find vulnerabilities.

Security researcher : Someone who practice pen testing and browse the web to find phishing/fake websites, infected servers, bugs or vulnerabilities. He can work for a company as a security consultant, he is most likely a Blue teamer.

Reverse engineering : Reverse engineering, also called back engineering, is the process by which a man-made object is deconstructed to reveal its designs, architecture, or to extract knowledge from the object. Similar to scientific research, the only difference being that scientific research is about a natural phenomenon.Wikipedia

Social engineering : In the context of information security, it refers to psychological manipulation of people into performing actions or divulging confidential information. A type of confidence trick for the purpose of information gathering, fraud, or system access, it differs from a traditional "con" in that it is often one of many steps in a more complex fraud scheme. The term "social engineering" as an act of psychological manipulation of a human, is also associated with the social sciences, but its usage has caught on among computer and information security professionals.Wikipedia

Threat analyst : A threat hunter, also called a cybersecurity threat analyst, is a security professional or managed service provider (MSP) that proactively uses manual or machine-assisted techniques to detect security incidents that may elude the grasp of automated systems. Threat hunters aim to uncover incidents that an enterprise would otherwise not find out about, providing chief information security officers (CISOs) and chief information officers (CIOs) with an additional line of defense against advanced persistent threats (APTs).SearchCIO

(Table of Contents)

Difference between hacking and ethical hacking

A black hat is practicing penetration testing, but unlike a white hat, this is not ethical hacking. Ethical hacking is about find vulnerabilities and improve the security of a system. An ethical hacker is the ultimate security professional. Ethical hackers know how to find and exploit vulnerabilities and weaknesses in various systems, just like a malicious hacker (a black hat hacker). In fact, they both use the same skills; however, an ethical hacker uses those skills in a legitimate, lawful manner to try to find vulnerabilities and fix them before the bad guys can get there and try to break in. An ethical hacker is basically a white hat hacker.

(Table of Contents)

Languages

  • Python
  • Ruby
  • C / C++ / C#
  • Perl
  • PHP
  • Go
  • Java
  • Bash

(Table of Contents)

Content Management Systems

  • Wordpress
  • Joomla
  • Drupal
  • SPIP

These are the most used Content Management Systems (CMS). See a complete listhere.

(Table of Contents)

Basic steps of pen testing

(Table of Contents)

Tools by category

🕵️‍♂️ Information Gathering

Information Gathering tools allows you to collect host metadata about services and users. Check informations about a domain, IP address, phone number or an email address.

ToolLanguageSupportDescription
Th3inspectorPerlLinux/Windows/macOSAll in one tool for Information Gathering written in Perl.
CripsPythonLinux/Windows/macOSIP Tools To quickly get information about IP Address's, Web Pages and DNS records.
theHarvesterPythonLinux/Windows/macOSE-mails, subdomains and names Harvester.
ScanlessPythonLinux/Windows/macOSOnline port scan scraper.
CTFRPythonLinux/Windows/macOSAbusing Certificate Transparency logs for getting HTTPS websites subdomains.
Sn1perbashLinux/macOSAutomated Pentest Recon Scanner.
ReconDogPythonLinux/Windows/macOSRecon Dog is an all in one tool for all your basic information gathering needs.
RED HawkPHPLinux/Windows/macOSAll in one tool for Information Gathering, Vulnerability Scanning and Crawling. A must have tool for all penetration testers.
InfogaPythonLinux/Windows/macOSEmail Information Gathering.
KnockMailPythonLinux/Windows/macOSCheck if email address exists.
PhotonPythonLinux/Windows/macOSCrawler which is incredibly fast and extracts urls, emails, files, website accounts and much more.
RapidscanPythonLinux/Windows/macOSThe Multi-Tool Web Vulnerability Scanner.
a2svPythonLinux/Windows/macOSAuto Scanning to SSL Vulnerability.
WfuzzPythonLinux/Windows/macOSWeb application fuzzer.
NmapC/C++Linux/Windows/macOSScanner ports vulnerability.
DracnmapShellLinux/Windows/macOSopen source program which is using to exploit the network and gathering information with nmap

🔒 Password Attacks

Crack passwords and create wordlists.

ToolLanguageSupportDescription
John the RipperCLinux/Windows/macOSJohn the Ripper is a fast password cracker.
hashcatCLinux/Windows/macOSWorld's fastest and most advanced password recovery utility.
HydraCLinux/Windows/macOSParallelized login cracker which supports numerous protocols to attack.
ophcrackC++Linux/Windows/macOSWindows password cracker based on rainbow tables.
NcrackCLinux/Windows/macOSHigh-speed network authentication cracking tool.
WGenPythonLinux/Windows/macOSCreate awesome wordlists with Python.
SSH AuditorGoLinux/macOSThe best way to scan for weak ssh passwords on your network.
📝 Wordlists
ToolDescription
Probable WorlistWordlists sorted by probability originally created for password generation and testing.

🌐 Wireless Testing

Used for intrusion detection and wifi attacks.

ToolLanguageSupportDescription
AircrackCLinux/Windows/macOSWiFi security auditing tools suite.
bettercapGoLinux/Windows/macOS/Androidbettercap is the Swiss army knife for network attacks and monitoring.
WiFi PumpkinPythonLinux/Windows/macOS/AndroidFramework for Rogue Wi-Fi Access Point Attack.
AirgeddonShellLinux/Windows/macOSThis is a multi-use bash script for Linux systems to audit wireless networks.
AirbashCLinux/Windows/macOSA POSIX-compliant, fully automated WPA PSK handshake capture script aimed at penetration testing.

🔧 Exploitation Tools

Acesss systems and data with service-oriented exploits.

ToolLanguageSupportDescription
SQLmapPythonLinux/Windows/macOSAutomatic SQL injection and database takeover tool.
XSStrikePythonLinux/Windows/macOSAdvanced XSS detection and exploitation suite.
CommixPythonLinux/Windows/macOSAutomated All-in-One OS command injection and exploitation tool.

👥 Sniffing & Spoofing

Listen to network traffic or fake a network entity.

ToolLanguageSupportDescription
WiresharkC/C++Linux/Windows/macOSWireshark is a network protocol analyzer.
WiFi PumpkinPythonLinux/Windows/macOS/AndroidFramework for Rogue Wi-Fi Access Point Attack.
ZarpPythonLinux/Windows/macOSA free network attack framework.

🚀 Web Hacking

Exploit popular CMSs that are hosted online.

ToolLanguageSupportDescription
WPScanRubyLinux/Windows/macOSWPScan is a black box WordPress vulnerability scanner.
DroopescanPythonLinux/Windows/macOSA plugin-based scanner to identify issues with several CMSs, mainly Drupal & Silverstripe.
JoomscanPerlLinux/Windows/macOSJoomla Vulnerability Scanner.
DrupwnPythonLinux/Windows/macOSDrupal Security Scanner to perform enumerations on Drupal-based web applications.
Webpwn3rPythonLinux/Windows/macOSWeb Applications Security Scanner.
CMSeekPythonLinux/Windows/macOSCMS Detection and Exploitation suite - Scan WordPress, Joomla, Drupal and 130 other CMSs.

🎉 Post Exploitation

Exploits for after you have already gained access.

ToolLanguageSupportDescription
TheFatRatJavaLinux/Windows/macOSEasy tool to generate backdoor and easy tool to post exploitation attack like browser attack, dll.
MicrosploitShellLinux/Windows/macOSFast and easy create backdoor office exploitation using module metasploit packet , Microsoft Office , Open Office , Macro attack , Buffer Overflow.

📦 Frameworks

Frameworks are packs of pen testing tools with custom shell navigation and documentation.

ToolLanguageSupportDescription
Operative FrameworkPythonLinux/Windows/macOSFramework based on fingerprint action, this tool is used for get information on a website or a enterprise target with multiple modules.
MetasploitRubyLinux/Windows/macOSA penetration testing framework for ethical hackers.
fsocietyPythonLinux/Windows/macOSfsociety Hacking Tools Pack – A Penetration Testing Framework.
cSploitJavaAndroidThe most complete and advanced IT security professional toolkit on Android.
radare2CLinux/Windows/macOS/AndroidUnix-like reverse engineering framework and commandline tools.
Social Engineer ToolkitPythonLinux/macOSPenetration testing framework designed for social engineering.
hate_crackPythonLinux/macOSA tool for automating cracking methodologies through Hashcat.
WifiphisherPythonLinuxThe Rogue Access Point Framework.
KickthemoutPythonLinux/macOSKick devices off your network by performing an ARP Spoof attack.
BeefJavascriptLinux/Windows/macOSThe Browser Exploitation Framework. It is a penetration testing tool that focuses on the web browser.

(Table of Contents)

Additional resources

Books / Manuals

Warning : I haven't read them all so do not consider I am recommanding as I liked them. They just seems to provide useful resources.

Discussions

  • Reddit/HowToHack Learn and ask about hacking, security and pen testing.
  • Reddit/hacking Discuss about hacking and web security.
  • ax0nes Hacking, security, and software development forum.
  • 0Day.rocks on discord Discord server about the 0day.rocks blog for technical and general InfoSec/Cyber discussions & latest news.

Security Advisories

Challenges

(Table of Contents)

License

This repository is under MIT license.

(Table of Contents)


[8]ページ先頭

©2009-2025 Movatter.jp