使用python raw socket进行TCP SYN扫描

1. TCP SYN扫描

端口扫描常用于用于探测服务器或主机开放端口情况,被计算机管理员用于确认安全策略,同时被攻击者用于识别目标主机上的可运作的网络服务。端口扫描是向一定范围的服务器端口发送对应请求,以此确认可使用的端口。虽然其本身并不是恶意的网络活动,但也是网络攻击者探测目标主机服务,以利用该服务的已知漏洞的重要手段。

TCP SYN扫描是端口扫描众多方式中的一种,其他方式包括TCP扫描,UDP扫描,ACK扫描,窗口扫描和FIN扫描等。

TCP SYN扫描是另一种TCP扫描。端口扫描工具不使用操作系统原生网络功能,而是自行生成、发送IP数据包,并监控其回应。这种扫描模式被称为“半开放扫描”,因为它从不建立完整的TCP连接。端口扫描工具生成一个SYN包,如果目标端口开放,则会返回SYN-ACK包。扫描端回应一个RST包,然后在握手完成前关闭连接。如果端口关闭了但未使用过滤,目标端口应该会持续返回RST包。

TCP SYN扫描优点:

给扫描工具全权控制数据包发送和等待回应时长的权力,允许更详细的回应分析。

SYN扫描从不会建立完整的连接。

2. python 代码

使用raw socket进行SYN 洪泛,封装多个函数使其模块化和易于理解。利用结构体可以方便的使用格式化字符串和变量列表来编码数据包。

  1. /bin/env python  
  2. # -*- coding: UTF-8 -*-   
  3.  
  4. # 必须以root权限运行  
  5.  
  6. import socket  
  7. import sys  
  8. import time  
  9.  
  10. from struct import *  
  11.  
  12. # 计算校验和  
  13. def checksum(msg):  
  14.     s = 0 
  15.     # 每次取2个字节  
  16.     for i in range(0,len(msg),2):  
  17.         w = (ord(msg[i]) << 8) + (ord(msg[i+1]))  
  18.         s = s+w  
  19.  
  20.     s = (s>>16) + (s & 0xffff)  
  21.     s = ~s & 0xffff 
  22.  
  23.     return s  
  24.  
  25. def CreateSocket(source_ip,dest_ip):  
  26.     try:  
  27.         s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_TCP)  
  28.     except socket.error, msg:  
  29.         print 'Socket create error: ',str(msg[0]),'message: ',msg[1]  
  30.         sys.exit()  
  31.  
  32.     # 设置手工提供IP头部  
  33.     s.setsockopt(socket.IPPROTO_TCP, socket.IP_HDRINCL, 1)  
  34.     return s  
  35.  
  36. # 创建IP头部  
  37. def CreateIpHeader(source_ip, dest_ip):  
  38.     packet = '' 
  39.  
  40.     # ip 头部选项  
  41.     headerlen = 5 
  42.     version = 4 
  43.     tos = 0 
  44.     tot_len = 20 + 20 
  45.     id = random.randrange(18000,65535,1)  
  46.     frag_off = 0 
  47.     ttl = 255 
  48.     protocol = socket.IPPROTO_TCP  
  49.     check = 10 
  50.     saddr = socket.inet_aton ( source_ip )  
  51.     daddr = socket.inet_aton ( dest_ip )  
  52.     hl_version = (version << 4) + headerlen  
  53.     ip_header = pack('!BBHHHBBH4s4s', hl_version, tos, tot_len, id, frag_off, ttl, protocol, check, saddr, daddr)  
  54.  
  55.     return ip_header  
  56.  
  57. # 创建TCP头部  
  58. def create_tcp_syn_header(source_ip, dest_ip, dest_port):  
  59.     # tcp 头部选项  
  60.     source = random.randrange(32000,62000,1)    # 随机化一个源端口  
  61.     seq = 0 
  62.     ack_seq = 0 
  63.     doff = 5 
  64.     # tcp flags  
  65.     fin = 0 
  66.     syn = 1 
  67.     rst = 0 
  68.     psh = 0 
  69.     ack = 0 
  70.     urg = 0 
  71.     window = socket.htons (8192)    # 最大窗口大小  
  72.     check = 0 
  73.     urg_ptr = 0 
  74.     offset_res = (doff << 4) + 0 
  75.     tcp_flags = fin + (syn<<1) + (rst<<2) + (psh<<3) + (ack<<4) + (urg<<5)  
  76.     tcp_header = pack('!HHLLBBHHH', source, dest_port, seq, ack_seq, offset_res, tcp_flags, window, check, urg_ptr)  
  77.     # 伪头部选项  
  78.     source_address = socket.inet_aton( source_ip )  
  79.     dest_address = socket.inet_aton( dest_ip )  
  80.     placeholder = 0 
  81.     protocol = socket.IPPROTO_TCP  
  82.     tcp_length = len(tcp_header)  
  83.     psh = pack('!4s4sBBH', source_address, dest_address, placeholder, protocol, tcp_length);  
  84.     psh = psh + tcp_header;  
  85.     tcp_checksum = checksum(psh)  
  86.  
  87.     # 重新打包TCP头部,并填充正确地校验和  
  88.     tcp_header = pack('!HHLLBBHHH', source, dest_port, seq, ack_seq, offset_res, tcp_flags, window, tcp_checksum, urg_ptr)  
  89.     return tcp_header  
  90.  
  91.  
  92. def range_scan(source_ip, dest_ip, start_port, end_port) :  
  93.     syn_ack_received = []   # 开放端口存储列表  
  94.  
  95.     for j in range (start_port, end_port) :  
  96.         s = CreateSocket(source_ip, dest_ip)  
  97.         ip_header = CreateIpHeader(source_ip, dest_ip)  
  98.         tcp_header = create_tcp_syn_header(source_ip, dest_ip,j)  
  99.         packet = ip_header + tcp_header  
  100.  
  101.         s.sendto(packet, (dest_ip, 0))  
  102.  
  103.         data = s.recvfrom(1024) [0][0:]  
  104.  
  105.         ip_header_len = (ord(data[0]) & 0x0f) * 4 
  106.         ip_header_ret = data[0: ip_header_len - 1]  
  107.         tcp_header_len = (ord(data[32]) & 0xf0)>>2 
  108.         tcp_header_ret = data[ip_header_len:ip_header_len+tcp_header_len - 1]  
  109.  
  110.         if ord(tcp_header_ret[13]) == 0x12# SYN/ACK flags   
  111.             syn_ack_received.append(j)  
  112.     return syn_ack_received  
  113.  
  114.  
  115. # 程序从这里开始:  
  116. open_port_list = []  
  117. ipsource = '192.168.1.95' 
  118. ipdest = '192.168.1.31' 
  119. start = 100 
  120. stop = 450 
  121. step = (stop-start)/10 
  122. scan_ports = range(start, stop, step)  
  123. if scan_ports[len(scan_ports)-1] < stop:  
  124.     scan_ports.append(stop)  
  125. for i in range(len(scan_ports)-1):  
  126.     opl = range_scan(ipsource, ipdest, scan_ports[i], scan_ports[i+1])  
  127.     open_port_list.append(opl)  
  128. for i in range(len(open_port_list)):  
  129.     print 'Process #: ',i,' Open ports: ',open_port_list[i]  
  130. print 'A list of all open ports found: ' 
  131. for i in range(len(open_port_list)):  
  132.     for j in range(len(open_port_list[i])):  
  133.         print open_port_list[i][j],', ' 

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/138557.html<

(0)
运维的头像运维
上一篇2025-03-03 01:57
下一篇 2025-03-03 01:58

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注