What is a Port Scanner? - A port scanner is a simple program that scans a computer for open ports. The one we are going to make uses TCP. It uses the three way handshake to look for open ports. You can compare it to a thief going on his "scout-tour". e goes to a house before he breaks in and checks every door and window to see if anything is open so he can enter later that night without forcing something. Why would I need one? -A port scanner can serve many purposes, you can check to see if you are infected with a certain Trojan by checking your computer's open ports for specific Trojan ports. Or it can be used to see if a victim has any vulnerable ports open that can be used to gain further access to the machine. How can I create one with visual basic 6.0? - First we need to add the winsock control to our tool box so create a new project and go to the components screen (ctrl+t) then check the box next to Microsoft winsock control 6.0, and press ok. After that the control should be added to your toolbar on the left, just drag one to your form. Now create 2 textboxes, 2 buttons, 1 timer and 1 listbox. The first textbox is for the ip's, the second is for the starting port, the first button is for starting the scan, the second one is to stop the scanning. Then go to the timer and in the properties on the right change enabled to false and interval to 1000. If you like to fancy up your form with some warm colors and a fluffy border be my guest. Next go to the code window and type in the following. Private Sub Command1_Click() Winsock1.RemoteHost = Text1.Text ' The ip address or url to connect to Winsock1.RemotePort = Text2.Text ' The first port Winsock1.Connect Timer1.Enabled = True ' the rest of the ports. End Sub Private Sub Timer1_Timer() ' closes the last connection Winsock1.Close Text2.Text = Int(Text2.Text) + 1 'increases the port by one Winsock1.RemoteHost = Text1.Text Winsock1.RemotePort = Text2.Text Winsock1.Connect End Sub Now maybe you are wondering why I connected once an then enabled the timer to connect for the rest, well because of the line " Text2.Text = Int(Text2.Text) + 1 'increases the port by one " it doesn't scan the first port so you have to do it yourself . Now we have the scanning core of the port scanner, now we need something that says when it's open and when not. Private Sub Winsock1_Connect() List1.AddItem "Port " & Winsock1.RemotePort & " Is Open" End Sub This is why winsock is easy to use, everything you need is build in a nice sub. So we just code the connect sub so that when it is called by the winsock scanning for ports it puts the port number in the list. So that's basically it, but to make it complete we will code the stop button now, Private Sub Command2_Click() Timer1.Enabled = False ' stops the scanning timer Winsock1.Close ' closes any open winsock connection that was still open. End Sub That is it, you now have a simple working port scanner. Things you could do to make it better: - make a case statement in the winsock1.connect sub to recognize special ports. - make it multi threading so several sockets work with each other to scan faster. - make it output the scan result to a text file - etc |