日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢(xún)
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
使用pythonrawsocket進(jìn)行TCPSYN掃描

1. TCP SYN掃描

成都創(chuàng)新互聯(lián)公司長(zhǎng)期為上千多家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為正藍(lán)企業(yè)提供專(zhuān)業(yè)的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作,正藍(lán)網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。

端口掃描常用于用于探測(cè)服務(wù)器或主機(jī)開(kāi)放端口情況,被計(jì)算機(jī)管理員用于確認(rèn)安全策略,同時(shí)被攻擊者用于識(shí)別目標(biāo)主機(jī)上的可運(yùn)作的網(wǎng)絡(luò)服務(wù)。端口掃描是向一定范圍的服務(wù)器端口發(fā)送對(duì)應(yīng)請(qǐng)求,以此確認(rèn)可使用的端口。雖然其本身并不是惡意的網(wǎng)絡(luò)活動(dòng),但也是網(wǎng)絡(luò)攻擊者探測(cè)目標(biāo)主機(jī)服務(wù),以利用該服務(wù)的已知漏洞的重要手段。

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

TCP SYN掃描是另一種TCP掃描。端口掃描工具不使用操作系統(tǒng)原生網(wǎng)絡(luò)功能,而是自行生成、發(fā)送IP數(shù)據(jù)包,并監(jiān)控其回應(yīng)。這種掃描模式被稱(chēng)為“半開(kāi)放掃描”,因?yàn)樗鼜牟唤⑼暾腡CP連接。端口掃描工具生成一個(gè)SYN包,如果目標(biāo)端口開(kāi)放,則會(huì)返回SYN-ACK包。掃描端回應(yīng)一個(gè)RST包,然后在握手完成前關(guān)閉連接。如果端口關(guān)閉了但未使用過(guò)濾,目標(biāo)端口應(yīng)該會(huì)持續(xù)返回RST包。

TCP SYN掃描優(yōu)點(diǎn):

給掃描工具全權(quán)控制數(shù)據(jù)包發(fā)送和等待回應(yīng)時(shí)長(zhǎng)的權(quán)力,允許更詳細(xì)的回應(yīng)分析。

SYN掃描從不會(huì)建立完整的連接。

2. python 代碼

使用raw socket進(jìn)行SYN 洪泛,封裝多個(gè)函數(shù)使其模塊化和易于理解。利用結(jié)構(gòu)體可以方便的使用格式化字符串和變量列表來(lái)編碼數(shù)據(jù)包。

 
 
  1. /bin/env python  
  2. # -*- coding: UTF-8 -*-   
  3.  
  4. # 必須以root權(quán)限運(yùn)行  
  5.  
  6. import socket  
  7. import sys  
  8. import time  
  9.  
  10. from struct import *  
  11.  
  12. # 計(jì)算校驗(yàn)和  
  13. def checksum(msg):  
  14.     s = 0 
  15.     # 每次取2個(gè)字節(jié)  
  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.     # 設(shè)置手工提供IP頭部  
  33.     s.setsockopt(socket.IPPROTO_TCP, socket.IP_HDRINCL, 1)  
  34.     return s  
  35.  
  36. # 創(chuàng)建IP頭部  
  37. def CreateIpHeader(source_ip, dest_ip):  
  38.     packet = '' 
  39.  
  40.     # ip 頭部選項(xiàng)  
  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. # 創(chuàng)建TCP頭部  
  58. def create_tcp_syn_header(source_ip, dest_ip, dest_port):  
  59.     # tcp 頭部選項(xiàng)  
  60.     source = random.randrange(32000,62000,1)    # 隨機(jī)化一個(gè)源端口  
  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.     # 偽頭部選項(xiàng)  
  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頭部,并填充正確地校驗(yàn)和  
  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 = []   # 開(kāi)放端口存儲(chǔ)列表  
  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. # 程序從這里開(kāi)始:  
  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],', ' 

網(wǎng)頁(yè)題目:使用pythonrawsocket進(jìn)行TCPSYN掃描
標(biāo)題URL:http://m.5511xx.com/article/djhdgos.html