基于Python实现的网络端口扫描器

一、端口扫描原理

1.TCP扫描

1.1TCP全扫描(connect)

该方式使用系统API connect向目的主机的端口发出连接请求,如果无法连接,则认为目的主机的该端口关闭。
优点:建立TCP连接,保证了可靠性;编程较简单
缺点:需要建立完整的TCP连接,因此扫描速度较慢,并且采取该方式会在目的主机留下记录,不够隐蔽

1.2TCP半扫描(SYN)

该方式并未建立一个完整的TCP连接,在最初会向目的主机发送TCP SYN请求报文段,该报文段的目的端口是想要扫描的目标端口,如果目的主机的该端口处于开放状态,则会返回一个SYN/ACK报文段作为响应,其中SYN和ACK的标志位都是1
优点:速度较快
缺点:和connect相比,不够可靠,实现稍微复杂

1.3TCP隐私扫描(FIN)

在数据传输完成之后,主动结束的一方会发送一个FIN报文(此步骤是四次挥手的第一步),如果目标端口没有位处于listening状态,则会返回一个RST应答。反之,则不会有任何反应
优点:隐蔽性好,速度快
缺点:只能用于Linux系统,在Windows系统下,无论端口是否处于监听状态都会返回RST应答,因此无法在Windows系统中判断端口是否开放

2.UDP扫描

UDP(用户数据报协议)是面向非连接的,可将其理解为“不负责任”,因此可靠性不高。UDP扫描是向目的主机发送UDP数据包并等待响应,如果无响应,则认为 端口是开放的,如果收到ICMP不可达,则说明该端口是关闭的。
优点:在Linux和Windows中都能够使用
缺点:在等待响应过程中,可能是ICMP不可达,但是由于可靠性低,导致响应数据包丢失,从而误以为端口开放

相关函数功能介绍

socket函数

socket创建函数

socket.socket(socket_family,socket_type,protocal=0)

import socket
'''
socket.socket(socket_family,socket_type,protocal=0)
参数介绍:
socket_family:指定通信的“域”,常用AF_INET(IPv4网络通信)或者AF_UNIX(本地通信)
socket_type:通信类型,使用SOCK_STREAM(TCP传输控制协议)或者SOCK_DGRAM(UDP传输控制协议)
protocal常默认为0
'''
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)

如果socket创建失败,会抛出一个socket.error,对于该错误必须进行相应处理

import socket
try:
	s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)#创建套接字
    s.settimeout(timeout)
except socket.error, msg:
	s.exit()

socket连接函数

使用socket.connect_ex()函数,连接成功返回0

import socket
socket.connect(ip,port)#主动初始化并连接
socket.connect_ex(ip,port)#上述函数的扩展版本,出错时抛出一个异常而不是一个错误

socket域名转换函数

import socket
socket.gethostname(host)#将host转换为对应的ip地址,返回str

实现域名到IP地址的转换

实现代码

TCP 全连接扫描

#TCP_CON.py
import sys
import socket
import queue
import threading
from Security.PortList import get_port_list
class ConScanner(object):
    '''
    使用类(class)来封装,采用多线程
    '''
    class ConScan(threading.Thread): #自定义端口扫描线程类
        def __init__(self, port_queue, ip, timeout = 3):
            '''
            初始化参数
            '''
            threading.Thread.__init__(self)
            self.port_queue = port_queue
            self.ip = ip
            self.timeout = timeout
        def run(self):
            '''
            如果端口队列不为空,说明端口段没有扫描完,将继续取出端口进行扫描,直到队列为空
            '''
            while True:
                if self.port_queue.empty():
                    break
                OPEN_MSG = "Port %d OPEN\n"
                port = self.port_queue.get(timeout = 0.5)
                ip  = self.ip
                timeout = self.timeout
                try:
                    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)#创建套接字
                    s.settimeout(timeout)
                    result_code = s.connect_ex(
支持多线程快速扫描 支持网段扫描: ScanPort.py 支持自定义网段扫描: ScanPort.py 192.168.2 支持自定义子网段扫描: ScanPort.py 192.168.3.100 192.168.3.120 支持Web端口自动显示链接: C:\>ScanPort.py Scanning [192.168.200.1]-[192.168.200.254] Total 254 ip(s)... 192.168.200.1 80 web http://192.168.200.1 192.168.200.81 80 web http://192.168.200.81 192.168.200.81 443 web https://192.168.200.81 192.168.200.99 80 web http://192.168.200.99 192.168.200.99 443 web https://192.168.200.99 192.168.200.115 80 web http://192.168.200.115 192.168.200.115 443 web https://192.168.200.115 192.168.200.123 80 web http://192.168.200.123 192.168.200.123 443 web https://192.168.200.123 192.168.200.130 80 web http://192.168.200.130 192.168.200.130 443 web https://192.168.200.130 192.168.200.133 80 web http://192.168.200.133 192.168.200.133 443 web https://192.168.200.133 192.168.200.144 80 web http://192.168.200.144 192.168.200.144 443 web https://192.168.200.144 192.168.200.151 8080 web http://192.168.200.151 192.168.200.160 443 web https://192.168.200.160 192.168.200.160 80 web http://192.168.200.160 192.168.200.163 80 web http://192.168.200.163 192.168.200.163 443 web https://192.168.200.163 192.168.200.163 1080 Proxy 192.168.200.168 80 web http://192.168.200.168 192.168.200.168 443 web https://192.168.200.168 192.168.200.168 1080 Proxy 192.168.200.173 8080 web http://192.168.200.173 192.168.200.173 443 web https://192.168.200.173 192.168.200.181 80 web http://192.168.200.181 192.168.200.181 443 web https://192.168.200.181 192.168.200.180 80 web http://192.168.200.180 192.168.200.180 443 web https://192.168.200.180 192.168.200.192 80 web http://192.168.200.192 192.168.200.192 443 web https://192.168.200.192 All RUN TIME : 97.0510001183s
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值