百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>服务器> 端口扫描有哪几种方式
分享文章到:

端口扫描有哪几种方式

发布时间:09/01 来源:未知 浏览: 关键词:

事件原因

(引荐教程:web效劳器平安)

笔者在写一个小工具,针对渗出测试中需要搜集的信息,使用足本主动化采集。而在这个模块中有个很难搞的部分就是端口banner 信息搜集,起初我尝试使用了python+nmap+多线程扫描,扫描20+的ip,等的花都谢了。。。而笔者目标是扫描200+的ip。下面我就针对端口扫描的技术停止剖析。

1、nmap探测端口

nmap在扫描多个主机的时候可以设定参数 --min-hostgroup ,设定这个参数可以并行扫描多个主机,将这些主机划分成组,然后一次扫描一个组。

举例:

--min-hostgroup 50 nmap 以50个主机为一组,在扫描完50个主机此前不会显示结果。

#coding=utf-8
import nmap 
from queue import Queue
from threading import Thread
def portscan(ip):
    portlist = []
    nm = nmap.PortScannerYield()
    for r in nm.scan(ip,ports='1-10000',arguments='-sS --min-hostgroup'):
        m = r[1]['scan'][ip]['tcp']
        for p in m:
            temp = str(p) + "----" +m[p]['state']
            portlist.append(temp)
    print(portlist)
class Consumer(Thread):
    def __init__(self, q):
        Thread.__init__(self)
        self.q = q
    def run(self):
        while  not self.q.empty():
            ip = self.q.get()
            try:
                portscan(ip)
            except Exception as e:
                print(e)
                continue
def producer(ip_list):
    num = 10
    threads = []
    q = Queue()
    for i in ip_list:
        print(i)
        q.put(i)
    threads = [Consumer(q) for i in range(0,int(num))]
    for t in threads:
        t.start()
    for t in threads:
        t.join()
ip_list =['120.78.207.76', '120.78.207.231', '120.78.207.18', '120.78.207.233', '120.78.207.165', '120.78.207.48', 
'120.78.207.112', '120.78.207.27', '120.78.207.51', '120.78.207.8']
producer(ip_list)

e1fa1488b16b68dd29fb3b64d36b179.png

如图,运转10个ip需要318s。

2、masscan探测端口

(1)调取python masscan

默许状况下,masscan 发送的是syn数据包,假如目标主机返回ack+syn,则说明端口开放。详细流程如下

A:192.168.70.142

B:192.168.0.143 开放端口3306

(1)A->B syn

(2)B->A syn+ack

(3)A->B RST

d6f7a278cc533dacc85d265eef438f6.png

探测未开放的端口

A->B syn

B->A rst

6d8932cd5f6c4beb60b8d9f2cdc772e.png

举例:

def portscan(ip):
    mas = masscan.PortScanner()
    mas.scan(ip,ports='1-65535')
    print(mas.scan_result)

使用系统命令探测

使用办法

扫描扫描443端口的B类子网
Masscan 10.11.0.0/16 -p443
扫描80或443端口的B类子网
Masscan 10.11.0.0/16 -p80,443
扫描100个常见端口的B类子网,每秒100,000个数据包
Masscan 10.11.0.0/16  --top-ports 100 -rate 100000

结果输出
-oX filename:输出到filename的XML。
-oG filename:输出到filename在的grepable格局。
-oJ filename:输出到filename在JSON格局。

3、socket探测端口

socket 探测端口发送的不是完全的三次握手包如下,

A:192.168.70.142

B:192.168.0.143 开放端口3306

A接收到B返回的syn+ack数据包后,A把数据抛弃。

097478369e319b15c30e3c4df84d686.png

探测不开放端口

A发送syn,B没有开放33端口,所以返回RST数据包。

794bf36a5ad4d87874d11368f9cb057.png

def portscan(ip,port):
    try:
        s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
        s.settimeout(0.2)
        status = s.connect_ex((ip,port))
        if status == 0:
            temp_str = str(ip) + "---" + str(port) + "---open"
            port_list.append(temp_str)
        else:
            pass
    except Exception as e:
        pass
    finally:
        s.close()

6454bd2648b1e56ce07a96a0160d753.png

探测10个ip花费了26.3s差不多一个2.6s。

4、telnet探测端口

telnet 探测端口采纳完全的三次握手连接,使用命令 telnet ip port ,发包流程如下

A:192.168.70.142

B:192.168.0.143 开放端口3306

telnet 192.168.0.143 3306

历程如下:

使用TCP三次握手创立连接: SYN -> SYN+ACK + ACK

36a6d07df2eba422d7c2e56e6903e4b.png

探测不存在端口,发送SYN数据包,然后RST包抛弃。

be0595a2cf52b5ac41731bfeb6d9ea1.png

假如有返回值,则说明端口开放,不然则端口关闭。

def portscan(ip,port):
     try:
         t = telnetlib.Telnet(ip,port=port,timeout=0.2)
         if t:
             temp_str = str(ip) + '---' + str(port)
             port_list.append(temp_str)
 except Exception as e:
     print(e)
     pass

77cdbf1c5c969e081ee922e8d0ee8f3.png

探测10个ip花费了27.8s差不多一个2.7s。

5、nc探测端口

nc探测端口采纳完全的三次握手连接,使用命令 nc -v -w 1 -z ip port,发包历程和telent 探测一样。

探测开放端口的数据包

b5679be33a3c571270d3a2c67108f34.png

探测未开放端口的数据包

8048ee0f6e5f8527daf1fba419536bc.png

端口开放,返回值为0,可以依此作为推断根据。

def portscan(ip,port):
     command = 'nc -v -w 1 -z {0} {1}'.format(ip,port)
     m = os.system(command)
     if m == 0:
         temp_str = str(ip) + "---" + str(port)
         port_list.append(temp_str)
     else:
         pass

eb3b07b6312ba4d7f28fc8f58d4c8bf.png

备注:比方你想探测某个指定的端口开放状况,引荐使用nc。

总结

nmap 作为扫描端口的神器,扫描出的结果比其他几种方式要具体。假如追求效力的话,倡议采纳socket。比拟于nmap,socket会存在漏报状况,笔者在测试某主机时,nmap扫出了8888端口,但是socket没有。

以上就是端口扫描有哪几种方式的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有152人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板