国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

python構(gòu)造IP報文實例

瀏覽:3日期:2022-07-26 13:12:09

我就廢話不多說了,大家還是直接看代碼吧!

import socketimport sysimport timeimport struct HOST, PORT = '10.60.66.66', 10086 def make_forward_iphdr(source_ip = ’1.0.0.1’, dest_ip = ’2.0.0.2’, proto = socket.IPPROTO_UDP) : # ip header fields ip_ihl = 5 ip_ver = 4 ip_tos = 0 ip_tot_len = 0 # kernel will fill the correct total length ip_id = 54321 #Id of this packet ip_frag_off = 0 ip_ttl = 255 ip_proto = proto ip_check = 0 # kernel will fill the correct checksum ip_saddr = socket.inet_aton ( source_ip ) #Spoof the source ip address if you want to ip_daddr = socket.inet_aton ( dest_ip ) ip_ihl_ver = (ip_ver << 4) + ip_ihl # the ! in the pack format string means network order ip_header = struct.pack(’!BBHHHBBH4s4s’, ip_ihl_ver, ip_tos, ip_tot_len, ip_id, ip_frag_off, ip_ttl, ip_proto, ip_check, ip_saddr, ip_daddr) return ip_header def make_forward_udphdr(src_port = 1024, dst_port = 10086) : udp_header = struct.pack(’!HHHH’, src_port, dst_port, 0, 0) return udp_header # checksum functions needed for calculation checksumdef checksum(msg): s = 0 # loop taking 2 characters at a time for i in range(0, len(msg), 2): w = ord(msg[i]) + (ord(msg[i+1]) << 8 ) s = s + w s = (s>>16) + (s & 0xffff); s = s + (s >> 16); #complement and mask to 4 byte short s = ~s & 0xffff return s def make_tcp_data(ip_header, src_port = 1024, dst_port = 10086, source_ip=’1.0.0.1’, dest_ip=’2.0.0.2’, user_data = ’test’) : tcp_source = src_port # source port tcp_dest = dst_port # destination port tcp_seq = 454 tcp_ack_seq = 0 tcp_doff = 5 #4 bit field, size of tcp header, 5 * 4 = 20 bytes #tcp flags tcp_fin = 0 tcp_syn = 1 tcp_rst = 0 tcp_psh = 0 tcp_ack = 0 tcp_urg = 0 tcp_window = socket.htons (5840) # maximum allowed window size tcp_check = 0 tcp_urg_ptr = 0 tcp_offset_res = (tcp_doff << 4) + 0 tcp_flags = tcp_fin + (tcp_syn << 1) + (tcp_rst << 2) + (tcp_psh <<3) + (tcp_ack << 4) + (tcp_urg << 5) # the ! in the pack format string means network order tcp_header = struct.pack(’!HHLLBBHHH’ , tcp_source, tcp_dest, tcp_seq, tcp_ack_seq, tcp_offset_res, tcp_flags, tcp_window, tcp_check, tcp_urg_ptr) source_address = socket.inet_aton(source_ip) dest_address = socket.inet_aton(dest_ip) placeholder = 0 protocol = socket.IPPROTO_TCP tcp_length = len(tcp_header) + len(user_data) psh = struct.pack(’!4s4sBBH’ , source_address , dest_address , placeholder , protocol , tcp_length); psh = psh + tcp_header + user_data; tcp_check = checksum(psh) #print tcp_checksum # make the tcp header again and fill the correct checksum - remember checksum is NOT in network byte order tcp_header = struct.pack(’!HHLLBBH’ , tcp_source, tcp_dest, tcp_seq, tcp_ack_seq, tcp_offset_res, tcp_flags, tcp_window) + struct.pack(’H’ , tcp_check) + struct.pack(’!H’ ,tcp_urg_ptr) # final full packet - syn packets dont have any data packet = ip_header + tcp_header + user_data return packet

補充知識:python做在域名作為關(guān)鍵字的POST報文集合分類

將報文按域名分成不同的集合,而后寫入excel,主要使用了字典數(shù)據(jù)結(jié)構(gòu)

輸入內(nèi)容:

[域名,post報文(一個域名有多條,在不同行),域名類型]

輸出內(nèi)容:

[域名,POST報文集合,域名類型]

#-*- encoding:UTF-8 -*-import openpyxlfrom openpyxl import load_workbookfrom openpyxl import Workbookimport numpy as npimport pandas as pdimport restrinfo = re.compile(’[ ]+’)book=load_workbook(’ex2.xlsx’,’utf-8’)sheet=book.worksheets[0]rows=sheet.max_rowcols=sheet.max_columnPost={}Type={}for i in range(2,rows+1):#向字典里添加元素 dn=sheet.cell(i,1).value pv=sheet.cell(i,2).value tv=sheet.cell(i,3).value if Post.get(dn)==None:#第一次遇到?個域名 Post[dn]=pv Type[dn]=tv else: Post[dn]+=’n’+pvwb=Workbook()sh=wb.worksheets[0]#輸出表格for i in range(2,rows+1):#從字典中取出內(nèi)容存入excel dn=sheet.cell(i,1).value if i==2: Post[dn]=Post[dn].replace(’/’,’ ’).replace(’:’,’ ’) Post[dn]=Post[dn].replace(’(’,’ ’).replace(’)’,’ ’) Post[dn]=Post[dn].replace(’*’,’ ’).replace(’;’,’ ’) Post[dn]=Post[dn].replace(’t’,’ ’).replace(’n’,’ ’) Post[dn]=Post[dn].replace(’$’,’ ’).replace(’@’,’ ’) Post[dn]=Post[dn].replace(’=’,’ ’).replace(’&’,’ ’) Post[dn]=Post[dn].replace(’,’,’ ’).replace(’?’,’ ’) Post[dn]=strinfo.sub(’ ’,Post[dn]) sh.append([dn,Post[dn],Type[dn]]) else: if dn!=sheet.cell(i-1,1).value: Post[dn]=Post[dn].replace(’/’,’ ’).replace(’:’,’ ’) Post[dn]=Post[dn].replace(’(’,’ ’).replace(’)’,’ ’) Post[dn]=Post[dn].replace(’*’,’ ’).replace(’;’,’ ’) Post[dn]=Post[dn].replace(’t’,’ ’).replace(’n’,’ ’) Post[dn]=Post[dn].replace(’$’,’ ’).replace(’@’,’ ’) Post[dn]=Post[dn].replace(’=’,’ ’).replace(’&’,’ ’) Post[dn]=Post[dn].replace(’,’,’ ’).replace(’?’,’ ’) Post[dn]=strinfo.sub(’ ’,Post[dn]) sh.append([dn,Post[dn],Type[dn]]) else: continuereplace(’_x000D_’,’’)wb.save(’out.csv’)

以上這篇python構(gòu)造IP報文實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 亚洲欧美男人天堂 | 亚洲男人的天堂在线视频 | 一区二区三区免费在线视频 | 成年人福利视频 | 天堂一区二区三区在线观看 | 亚洲欧美日韩国产一区二区精品 | 国产成人亚洲综合91精品555 | 在线看片亚洲 | 久久精品国产亚洲a | 国产乱子伦视频大全 | 国产亚洲一区二区手机在线观看 | 欧美精选欧美极品 | 久久观看 | 日韩精品一区二区在线观看 | 成年人毛片视频 | 一级一片免费看 | 天天综合色一区二区三区 | 欧美特黄aaaaaa | 男人的天堂在线 | 国产精品1区 2区 3区 | 午夜日b视频 | 欧美一区二区三区视频 | 国产盗摄一区二区 | 国产午夜三级 | 日韩免费一级片 | 草久视频在线 | 99久久国产综合精品网成人影院 | 亚洲毛片免费观看 | 欧美成人一级视频 | 亚洲一级毛片在线观播放 | 欧美影院久久 | 亚洲欧美成人综合在线 | 日本三级一区二区三区 | 99久久精品国产国产毛片 | 久久网站免费观看 | 国产一区二区播放 | 亚洲清纯自偷自拍另类专区 | 欧美日韩 在线播放 | 喷潮白浆| 黄色上床网站 | 91热视频在线观看 |