portscan


Nameportscan JSON
Version 1.1 PyPI version JSON
download
home_pagehttps://github.com/Aperocky/PortScan
SummarySimple port scanning utility at terminal
upload_time2023-10-26 01:38:13
maintainer
docs_urlNone
authorRocky Li
requires_python
licenseMIT
keywords port scanner multithreading queue terminal utility
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # PortScan

![PyPI version](http://img.shields.io/pypi/v/portscan.svg)   ![Python 3.x](http://img.shields.io/badge/Python-3.x-green.svg)   ![PyPI license](https://img.shields.io/github/license/mashape/apistatus.svg)   [![Downloads](https://pepy.tech/badge/portscan)](https://pepy.tech/project/portscan)

PortScan is a *light-weight* command line utility that allows user to conduct scanning over a range of IP addresses and port ranges with multi-threading. Helpful with finding local stuff like printer, headless raspberry pi, or scanning remote blocks for open ranges of ports.

Install: `pip install portscan`

Upgrade: `pip install portscan --upgrade`

Usage: `portscan [192.168.1.0/24] [-p 22,80-200 [-t 100 [-w 1 [-e]]]]`

```
$ portscan -w 0.2
No IP string found, using local address
Local IP found to be 192.168.1.175, scanning entire block
Threads will wait for ping response for 0.2 seconds
192.168.1.1:80 OPEN
192.168.1.1:443 OPEN
192.168.1.167:443 OPEN
192.168.1.167:80 OPEN
Pinged 1024 ports
```

By default the command checks for your *Local Area Network* IP first, and then initiate a block wise search. specify IP if you want to search any other IP blocks. *Note: This is not available before 0.2.1, please update or specify IP if you're using 0.2.0 and older*

Use `-w [float]` to change timeout settings from default of `3` seconds: for LAN, this can be as low as `0.1`. `1` is usually good enough for continental level connection.

To show more ports that have denied/refused connection, use `-e`, this will show you all ports that are not timed out.

```
$ portscan 174.109.64.0/24 -w 0.5 -e
Threads will wait for ping response for 0.5 seconds
174.109.64.3:443 ERRNO 61, Connection refused
174.109.64.3:23 ERRNO 61, Connection refused
174.109.64.3:80 ERRNO 61, Connection refused
174.109.64.3:22 ERRNO 61, Connection refused
174.109.64.88:80 ERRNO 61, Connection refused
174.109.64.88:23 ERRNO 61, Connection refused
174.109.64.88:443 ERRNO 61, Connection refused
174.109.64.88:22 ERRNO 61, Connection refused
174.109.64.125:443 OPEN
Pinged 1024 ports
```

### Arguments

`ip`: default and optional *(since 0.2.1, required before 0.2.1)* argument, can parse single IP, list of IP, IP blocks:

    192.168.1.0 # single IP

    192.168.1.0/24 # A 24 block, from 192.168.1.0 to 192.168.1.255

    [192.168.1.0/24,8.8.8.8] # The aforementioned 24 block and 8.8.8.8.

Options:

`-p`, `--port`: port range, default `22,23,80`, use `,` as a delimiter without space, support port range (e.g. `22-100,5000`).

`-t`, `--threadnum`: thread numbers, default 500, as of now, thread number have a hard cap of 2048. More thread will increase performance on large scale scans.

`-e`, `--show_refused`: show connection errors other than timeouts, e.g. connection refused, permission denied with errno number as they happen.

`-w`, `--wait`: Wait time for socket to respond. If scanning LAN or relatively fast internet connection, this can be set to `1` or even `0.1` for faster (local) scanning, but this runs a risk of missing the open ports. Default to `3` seconds

`-s`, `--stop_after`: Number of open ports to be discovered after which scan would be gracefully stopped. Default is None for not stopping. Note that it will continue to finish what's left in the queue, so the number of open ports returned might be greater than the value passed in.

## Python API

One can also use this portscan inside existing python scripts.

Consider following example for finding out adb port for Android device in LAN with static IP:
```python
from portscan import PortScan
ip = '192.168.1.42'
port_range = '5555,37000-44000'
scanner = PortScan(ip, port_range, thread_num=500, show_refused=False, wait_time=1, stop_after_count=True)
open_port_discovered = scanner.run()  # <----- actual scan
# run returns a list of (ip, open_port) tuples
adb_port = int(open_port_discovered[0][1])

# Usecase specific part
from adb_shell.adb_device import AdbDeviceTcp, AdbDeviceUsb
device1 = AdbDeviceTcp(ip, adb_port, default_transport_timeout_s=9)
device1.connect(rsa_keys=[python_rsa_signer], auth_timeout_s=0.1)  # adb connect
# shell exec
notifications_dump = device1.shell('dumpsys notification').encode().decode('ascii','ignore')
device1.close()

print(notifications_dump)
```

## Acknowledgement

Jamieson Becker: For coming up with a way to find local IP on stackoverflow, which I used: https://stackoverflow.com/questions/166506/finding-local-ip-addresses-using-pythons-stdlib

Mihir Parikh: Thanks for picking up my ancient project and verifying/supporting Windows and adding flags/return. And for convincing me to wrap it up and putting it in a better place than 4 years ago.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/Aperocky/PortScan",
    "name": "portscan",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "port,scanner,multithreading,queue,terminal,utility",
    "author": "Rocky Li",
    "author_email": "aperocky@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/a1/6d/7775666d4bfef404b32499c132e74db082ca2a36f33da8bb2fb85499c261/portscan-1.1.tar.gz",
    "platform": null,
    "description": "# PortScan\n\n![PyPI version](http://img.shields.io/pypi/v/portscan.svg) &nbsp; ![Python 3.x](http://img.shields.io/badge/Python-3.x-green.svg) &nbsp; ![PyPI license](https://img.shields.io/github/license/mashape/apistatus.svg) &nbsp; [![Downloads](https://pepy.tech/badge/portscan)](https://pepy.tech/project/portscan)\n\nPortScan is a *light-weight* command line utility that allows user to conduct scanning over a range of IP addresses and port ranges with multi-threading. Helpful with finding local stuff like printer, headless raspberry pi, or scanning remote blocks for open ranges of ports.\n\nInstall: `pip install portscan`\n\nUpgrade: `pip install portscan --upgrade`\n\nUsage: `portscan [192.168.1.0/24] [-p 22,80-200 [-t 100 [-w 1 [-e]]]]`\n\n```\n$ portscan -w 0.2\nNo IP string found, using local address\nLocal IP found to be 192.168.1.175, scanning entire block\nThreads will wait for ping response for 0.2 seconds\n192.168.1.1:80 OPEN\n192.168.1.1:443 OPEN\n192.168.1.167:443 OPEN\n192.168.1.167:80 OPEN\nPinged 1024 ports\n```\n\nBy default the command checks for your *Local Area Network* IP first, and then initiate a block wise search. specify IP if you want to search any other IP blocks. *Note: This is not available before 0.2.1, please update or specify IP if you're using 0.2.0 and older*\n\nUse `-w [float]` to change timeout settings from default of `3` seconds: for LAN, this can be as low as `0.1`. `1` is usually good enough for continental level connection.\n\nTo show more ports that have denied/refused connection, use `-e`, this will show you all ports that are not timed out.\n\n```\n$ portscan 174.109.64.0/24 -w 0.5 -e\nThreads will wait for ping response for 0.5 seconds\n174.109.64.3:443 ERRNO 61, Connection refused\n174.109.64.3:23 ERRNO 61, Connection refused\n174.109.64.3:80 ERRNO 61, Connection refused\n174.109.64.3:22 ERRNO 61, Connection refused\n174.109.64.88:80 ERRNO 61, Connection refused\n174.109.64.88:23 ERRNO 61, Connection refused\n174.109.64.88:443 ERRNO 61, Connection refused\n174.109.64.88:22 ERRNO 61, Connection refused\n174.109.64.125:443 OPEN\nPinged 1024 ports\n```\n\n### Arguments\n\n`ip`: default and optional *(since 0.2.1, required before 0.2.1)* argument, can parse single IP, list of IP, IP blocks:\n\n    192.168.1.0 # single IP\n\n    192.168.1.0/24 # A 24 block, from 192.168.1.0 to 192.168.1.255\n\n    [192.168.1.0/24,8.8.8.8] # The aforementioned 24 block and 8.8.8.8.\n\nOptions:\n\n`-p`, `--port`: port range, default `22,23,80`, use `,` as a delimiter without space, support port range (e.g. `22-100,5000`).\n\n`-t`, `--threadnum`: thread numbers, default 500, as of now, thread number have a hard cap of 2048. More thread will increase performance on large scale scans.\n\n`-e`, `--show_refused`: show connection errors other than timeouts, e.g. connection refused, permission denied with errno number as they happen.\n\n`-w`, `--wait`: Wait time for socket to respond. If scanning LAN or relatively fast internet connection, this can be set to `1` or even `0.1` for faster (local) scanning, but this runs a risk of missing the open ports. Default to `3` seconds\n\n`-s`, `--stop_after`: Number of open ports to be discovered after which scan would be gracefully stopped. Default is None for not stopping. Note that it will continue to finish what's left in the queue, so the number of open ports returned might be greater than the value passed in.\n\n## Python API\n\nOne can also use this portscan inside existing python scripts.\n\nConsider following example for finding out adb port for Android device in LAN with static IP:\n```python\nfrom portscan import PortScan\nip = '192.168.1.42'\nport_range = '5555,37000-44000'\nscanner = PortScan(ip, port_range, thread_num=500, show_refused=False, wait_time=1, stop_after_count=True)\nopen_port_discovered = scanner.run()  # <----- actual scan\n# run returns a list of (ip, open_port) tuples\nadb_port = int(open_port_discovered[0][1])\n\n# Usecase specific part\nfrom adb_shell.adb_device import AdbDeviceTcp, AdbDeviceUsb\ndevice1 = AdbDeviceTcp(ip, adb_port, default_transport_timeout_s=9)\ndevice1.connect(rsa_keys=[python_rsa_signer], auth_timeout_s=0.1)  # adb connect\n# shell exec\nnotifications_dump = device1.shell('dumpsys notification').encode().decode('ascii','ignore')\ndevice1.close()\n\nprint(notifications_dump)\n```\n\n## Acknowledgement\n\nJamieson Becker: For coming up with a way to find local IP on stackoverflow, which I used: https://stackoverflow.com/questions/166506/finding-local-ip-addresses-using-pythons-stdlib\n\nMihir Parikh: Thanks for picking up my ancient project and verifying/supporting Windows and adding flags/return. And for convincing me to wrap it up and putting it in a better place than 4 years ago.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Simple port scanning utility at terminal",
    "version": "1.1",
    "project_urls": {
        "Homepage": "https://github.com/Aperocky/PortScan"
    },
    "split_keywords": [
        "port",
        "scanner",
        "multithreading",
        "queue",
        "terminal",
        "utility"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e6dedf3a374079fc4963edc04458e7b4250ed267142188aabd089f3ce8510377",
                "md5": "2a821c55c40125e028cb68c9bbf19472",
                "sha256": "598066696fcd6e2cff858125af75eafca7f34de551dfd14e14b796dfe44c4725"
            },
            "downloads": -1,
            "filename": "portscan-1.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "2a821c55c40125e028cb68c9bbf19472",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 7346,
            "upload_time": "2023-10-26T01:38:11",
            "upload_time_iso_8601": "2023-10-26T01:38:11.320483Z",
            "url": "https://files.pythonhosted.org/packages/e6/de/df3a374079fc4963edc04458e7b4250ed267142188aabd089f3ce8510377/portscan-1.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a16d7775666d4bfef404b32499c132e74db082ca2a36f33da8bb2fb85499c261",
                "md5": "abd59e8a20796c05e84509519113b46e",
                "sha256": "ef0458b8635bfb984f9d52de19f7c0d5887910e8fdd10c786822b710b381d34c"
            },
            "downloads": -1,
            "filename": "portscan-1.1.tar.gz",
            "has_sig": false,
            "md5_digest": "abd59e8a20796c05e84509519113b46e",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 6914,
            "upload_time": "2023-10-26T01:38:13",
            "upload_time_iso_8601": "2023-10-26T01:38:13.274684Z",
            "url": "https://files.pythonhosted.org/packages/a1/6d/7775666d4bfef404b32499c132e74db082ca2a36f33da8bb2fb85499c261/portscan-1.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-10-26 01:38:13",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "Aperocky",
    "github_project": "PortScan",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "portscan"
}
        
Elapsed time: 3.46579s