Skip to main content

port scanner

Project description

PORTFINDER

Python Version License PyPI Version

Portfinder is a powerful asynchronous port scanner for Python that allows you to quickly scan multiple targets with flexible configuration options.

Navigation

Features

  • Scan multiple IPs, CIDR ranges or domains
  • Custom port ranges support (e.g., 1-1000,3389,8080)
  • Protocol-specific scanning (TCP, UDP, HTTP, HTTPS)
  • High-performance async I/O implementation
  • Multiple output formats (JSON, JSON Lines, plain text)
  • Quiet mode for scripting

Installation as Python Library PyPI

pip install portfinder

run basic scan

portfinder -t example.com

advanced scan

portfinder -t 192.168.1.1,10.0.0.0/24,example.com -p 1-1024,3389,8080 -P http -T 1.5 -c 500 -tps 300 -o scan_results -j
Argument Description
-t, --target Target IP/CIDR/domain (comma-separated) (required)
-p, --ports Ports to scan (default: 80,443,53)
-P, --protocol Protocol to check (tcp, udp, http, https)
-T, --timeout Timeout in seconds (default: 2.0)
-c, --concurrency Maximum concurrent connections per host (default: 300) no more than ~500-1000 on CPU cores
-o, --outfile Output file path (without extension)
-j, --js Output in JSON format
-jl, --jsl Output in JSON Lines format
-q, --quiet Disable all stdout output

basic python usage

from portfinder.scanner import Scanner
from portfinder.dto import Protocol, Result

async def run_scan():
    ...
    scanner = Scanner(
        target="0.0.0.0",
        ports="80-23000",
        protocol=Protocol.HTTP,
        timeout=4.0,
        concurrency=400,
        ip_pool_size=200,
    )
    results: list[Result] = await scanner.run()
    ...
  • Result is a active port item (dataclass) with attributes:
    • host: str
    • port: int
    • ip_version: IpVersion
    • protocols: list[Protocol]
  • Protocol enum:
    • HTTP,
    • HTTPS,
    • TCP,
    • UDP

output files format:

  • txt file
0.0.0.0:21 [ipv4] (tcp)
  • json file
[
  {
    "host": "0.0.0.0",
    "port": 21,
    "ip_version": "ipv4",
    "protocols": [
      [
        "tcp"
      ]
    ]
  }
]
  • jsonl file
{"host": "0.0.0.0", "port": 53, "ip_version": "ipv4", "protocols": [["tcp"]]}

powered by lynkey.io

License MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

portfinder-0.1.3.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

portfinder-0.1.3-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file portfinder-0.1.3.tar.gz.

File metadata

  • Download URL: portfinder-0.1.3.tar.gz
  • Upload date:
  • Size: 7.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.11.13 Darwin/24.3.0

File hashes

Hashes for portfinder-0.1.3.tar.gz
Algorithm Hash digest
SHA256 125952ee3bc8f05856fbf375351be60a17bef836845690645a013718dd583491
MD5 a7b7ebaa4de37a26e7bfa315da2d783a
BLAKE2b-256 267d02c076a47401d68a782e3c33aa8864cbb78d1570b54397dc42aa73757fd4

See more details on using hashes here.

File details

Details for the file portfinder-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: portfinder-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 8.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.11.13 Darwin/24.3.0

File hashes

Hashes for portfinder-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 92fdabda0c264346bb827b833f309b0805c441f5ad32ab8d67805a08cc0b9f63
MD5 39376b367dd0c1c6d40ba3c1d1a3295f
BLAKE2b-256 879a585b205d128f55010752a1d187bc87a2c9ff75605112e6e0a9bd830b053a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page