Simple Penetration Testing with Python Nmap-SecureMyOrg

featured image for the blog post on pentesting

In today’s digital landscape, cybersecurity threats lurk around every corner exploiting vulnerabilities in even the most secure systems. As technology advances, hackers adapt, making it crucial for organizations to stay one step ahead. Penetration testing, or pentesting, is a vital tool in the fight against cyber threats. In this article, we’ll delve into pentesting basics, types, and benefits, providing a comprehensive understanding of this essential security practice.

Network Penetration testing: image illustration

Table of Contents

comparison-chart-getting-started-with-pentesting

Penetration Testing is a specific type of ethical hacking that involves simulating real world attacks on a computer system, network or web application to test its defenses and identify vulnerabilities. Pentesters aim to mimic malicious hackers by using the same techniques but with permission and guidance of the organization being tested.

How is Pentesting Done?

pentesters-performing-a-pentest
performing a pentest

A ‘Pentest’ is a systematic process to identify, exploit and document the vulnerabilities in the computer system of an organization. It is done in a structural approach of 5 steps or phases:

  • Planning and Reconnaissance: Defining scope, gathering information, and identifying potential vulnerabilities.
  • Vulnerability scanning: Using automated tools like Nmap or Nessus to scan for vulnerabilities and identify open ports, services and potential entry points.
  • Exploitation and Post Exploitation: Attempting to exploit identified vulnerabilities, gaining access to systems or data, and escalating privileges.
  • Reporting and Recommendations: Documenting findings, providing recommendations for remediation and mitigation, and offering guidance on security best practices.
  • Remediation and Follow-up: Implementing fixes and patches, verifying effectiveness, and conducting re-testing to ensure vulnerabilities are addressed.

Types of Pentesting?

Penetration testing encompasses various types, each focusing on specific areas:

  • Black Box Pentesting: Testing without prior knowledge of the system or network.
  • White Box Pentesting: Testing with full knowledge of the system or network. Such as having access to the codebase from the client.
  • Gray Box Pentesting: A combination of black and white box testing.

What Are Some Tools Used To Perform A Pentest?

Pentesters utilize various tools and techniques, including:

  1. Nmap: Network scanning and mapping.
  2. Metasploit: Exploitation framework.
  3. Burp Suite: Web application security testing.
  4. Wireshark: Network protocol analysis.
  5. Kali Linux: Comprehensive pentesting distribution

What Programming Languages are used In Pentesting?

Python is a popular and versatile language used extensively in pentesting, particularly for exploit writing, general scripting, and automation. However, there are various other languages which are used depending on the specific goals of the pentest such as; Ruby, Perl, Java, SQL, etc..

In this article, we’ll demonstrate an example of a pentest using python by scanning a network for open ports. But first, let’s cover the basics: what are ports?

What Are Ports?

In computer networking, ports are virtual endpoints that allow communication between devices. There are 65,535 ports, divided into:

  1. Well-known ports (0-1023): Standardized ports for common services (e.g., HTTP, FTP, SSH).
  2. Registered ports (1024-49151): Assigned to specific services or applications.
  3. Private ports (49152-65535): Available for custom use.

Port scanning involves sending network requests to a target system to identify open ports and gather information about it.

Why scan for open ports in pentesting?

It is important to scan for open ports in penetration testing in order to:

  1. Identify potential entry points for attackers.
  2. Discover vulnerable services or applications.
  3. Map network architecture and services.
  4. Prioritize vulnerability exploitation.

An Example of a Pentest Using Python

Now that we have a clearer understanding of the what and why, let’s dive into an example of a Pentest using Python.

Let’s say we want to scan a network for open ports using the nmap library in Python.

 

Prerequisites

    • Python installed on your machine
    • Nmap installed on your machine
    • Install the python-nmap library using pip:
pip install python-nmap

Python Code Example

Here’s a simple Python script that uses the python-nmap library:


import nmap

def scan_open_ports(target_ip):
    nm = nmap.PortScanner()
    print(f"Scanning target: {target_ip}...\n")
    
    nm.scan(target_ip, arguments='-sS -Pn')  # TCP SYN scan, no ping

    if nm.all_hosts():
        for host in nm.all_hosts():
            print(f"Host: {host} ({nm[host].hostname()})")
            print(f"State: {nm[host].state()}")

            for proto in nm[host].all_protocols():
                lport = nm[host][proto].keys()
                for port in sorted(lport):
                    print(f"Port: {port}\tState: {nm[host][proto][port]['state']}")
    else:
        print("No hosts found.")

if __name__ == "__main__":
    target = input("Enter the target IP address or hostname: ")
    scan_open_ports(target)
    

How to Use This Script

    1. Copy the code into a file named port_scanner.py.
    2. Run the script using the command:
python port_scanner.py
  1. Input the target IP address or hostname when prompted.

Example Output

When you run the script, you might see output similar to the following:

Enter the target IP address or hostname: 192.168.1.1
Scanning target: 192.168.1.1...

Host: 192.168.1.1 (router)
State: up
Port: 22 State: open
Port: 80 State: open
Port: 443 State: open

Important Notes

  • Ensure you have permission to scan the target.
  • Nmap must be installed and accessible in your system’s PATH.
  • Some Nmap features require root privileges

Performing a penetration test using the Nmap library in Python involves utilizing python-nmap to scan networks, identify open ports, services, and potential vulnerabilities. Steps include installing python-nmap, importing the library, defining the target IP, configuring scan options, executing the scan, and parsing results. Various scan types are available, including TCP Connect, UDP, OS Detection, and Service Version Detection. Example code demonstrates how to scan a target IP, retrieve results, and parse findings.

What are the Benefits of Pentesting?

Pentesting offers numerous benefits to organizations, including:

  1. Improved Security Posture: Identifying vulnerabilities before attackers do.
  2. Reduced Risk: Minimizing potential breaches and data compromise.
  3. Compliance: Meeting regulatory requirements and avoiding fines.
  4. Cost Savings: Preventing costly breaches and downtime.
  5. Enhanced Incident Response: Developing effective response strategies.
  6. Better Resource Allocation: Prioritizing security efforts based on pentest findings.
  7. Increased Customer Trust: Demonstrating commitment to security and data protection

By incorporating pentesting, one can significantly improve his/her organization’s overall security posture and resilience.

Conclusion

Inn conclusion, pentesting is a vital component of a robust cybersecurity strategy. By understanding pentesting basics, types, and benefits, organizations can proactively strengthen their defenses, reduce risk, and protect sensitive data. Whether you’re a seasoned security professional or just starting out, pentesting is an essential tool in the fight against cyber threats.

References

Book A Free Security Consultation With SecureMyOrg!

SecureMyOrg is a reputable cybersecurity firm that has worked with renowned companies like Yahoo, Gojek and Rippling.

We build security for startups. If you’re someone looking for a trusted cybersecurity partner, feel free to reach out to us – LinkedIn or Email. Some of the things people reach out to us for –

  1. Building their cybersecurity program from scratch – setting up cloud security using cost-effective tools, SIEM for alert monitoring, building policies for the company
  2. Vulnerability Assessment and Penetration Testing ( VAPT ) – We have certified professionals, with certifications like OSCP, CREST – CPSA & CRT, CKA and CKS
  3. DevSecOps consulting
  4. Red Teaming activity
  5. Regular security audits, before product release
  6. Full time security engineers.

image illustrating patching an open port vulnerability with SecureMyOrg

Relevant Posts

kali-linux-logo image

Kali Linux for Penetration Testing: A Comprehensive Guide -SecureMyOrg

This blog explores why Kali Linux is a favorite among ethical hackers, its compatibility with Windows, and the hardware requirements needed to harness its power. Whether you’re a seasoned cybersecurity expert or a beginner stepping into the world of ethical hacking, Kali Linux is your gateway to mastering penetration testing

Read More »

Subscribe to our newsletter !

Please fill the form for a prompt response!