This post will walkthrough the creation of a python script for scanning open ports on a remote host using Kali Linux.
To begin, open a command terminal in Linux
data:image/s3,"s3://crabby-images/9fd0b/9fd0bae75adb413d522de6c100e0be7ddd835a14" alt=""
Create a file for the python script. This can be done using VIM and an appropriate file name ending in .py
data:image/s3,"s3://crabby-images/be932/be932f9375c8f21818379313102ed444a448c4c3" alt=""
Once inside the newly created file, the first lines of the script will be used to recruit pre-existing functions to make this script operational as seen below.
data:image/s3,"s3://crabby-images/feda2/feda220543668ef134687e498a305dd790ac50c2" alt=""
Now, for organizational purposes, comment out “Blank your screen” and follow it with the command below to do just that
data:image/s3,"s3://crabby-images/387ea/387ea839da359c992cd1ff03d0437e11ae14b2a0" alt=""
The next two lines instruct the script to ask for an input of the IP or host to be scanned and provides a location from which to retrieve the host information.
data:image/s3,"s3://crabby-images/b55da/b55da3de9e1ec0c78067bf0ae27aa6e5aa13f42e" alt=""
For the sake of visibility, the following lines in the script will create a banner with a message to indicate the process is running.
data:image/s3,"s3://crabby-images/030cb/030cb10a4c3815e39a42add2d61ea91ae0a9fb6e" alt=""
Next, a variable for the time and date the scan started will be assigned as “t1” (seen below)
data:image/s3,"s3://crabby-images/64afe/64afe02fe4cce76c855d728631550cc3ede4be83" alt=""
In the next screenshot, a loop argument is used to repeatedly run the process to determine the output for open ports detected within a given range.
data:image/s3,"s3://crabby-images/51af3/51af3a0d610b487f662eaccb8472fd9895dfa642" alt=""
Continuing, the next three blocks provide for error handling when the port scan is unsuccessful. Scenarios in which the user stops the scan, the hostname cannot be resolved or there is a failure to connect to the server, these blocks will print the appropriate error message to the terminal.
data:image/s3,"s3://crabby-images/31e88/31e88e058ac23898e1a5e4f530643551891181b7" alt=""
The last few entries in this script will define a second time variable, calculate the difference between the two time variables and print a completion message with time information when the scan is complete.
data:image/s3,"s3://crabby-images/bed12/bed12e6055a0f4cb8a7395085c9283c944fe5b6b" alt=""
Now, the script can be saved and run from the command terminal.
data:image/s3,"s3://crabby-images/61f92/61f9261a1875425e2e6714f4ba2040d5b5e6fe2f" alt=""
If everything is working correctly, the script will request a host to be scanned
data:image/s3,"s3://crabby-images/cede4/cede4704ff9c4fcca78657af42134008a931352d" alt=""
Type the host of choice and hit enter to watch the scan work as seen below
data:image/s3,"s3://crabby-images/10c9d/10c9d78c8d884c35be424f13803f2523e7c2b63d" alt=""
Ports 53 and 80 are open on this host and the scan took about thirty seconds to complete.