手机
当前位置:查字典教程网 >脚本专栏 >python >python基础教程之获取本机ip数据包示例
python基础教程之获取本机ip数据包示例
摘要:这几天用到了rawsocket,用python写了些demo程序,这里记录下。首先我们看一个简单的sniffer程序:复制代码代码如下:#!...

这几天用到了raw socket,用python写了些demo程序,这里记录下。

首先我们看一个简单的sniffer程序:

复制代码 代码如下:

#! /usr/bin/python

# code for linux

import socket

#s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_UDP)

s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_TCP)

while True:

print s.recvfrom(65535)

这里直接用raw socket接收数据,直接print操作。这个就几行代码,也没什么好解释的了,不懂的google下。

得到IP数据包后,接下来的工作就是对IP头进行解析,在这之前,我们先看看RFC中是怎么定义的(RFC791 : http://www.ietf.org/rfc/rfc791.txt ):

python基础教程之获取本机ip数据包示例1

即对应的图:

python基础教程之获取本机ip数据包示例2

从RFC和上图中可以看到IP数据包头各个字段所占的位数,我们可以根据这些定义去解析IP数据包头,然后根据相应的策略处理数据。

这里给出一段用python实现的解析IP头的代码(呵呵,是demo中的代码,只解析了前20个字节):

复制代码 代码如下:

def decodeIpHeader(packet):

mapRet = {}

mapRet["version"] = (int(ord(packet[0])) & 0xF0)>>4

mapRet["headerLen"] = (int(ord(packet[0])) & 0x0F)<<2

mapRet["serviceType"] = hex(int(ord(packet[1])))

mapRet["totalLen"] = (int(ord(packet[2])<<8))+(int(ord(packet[3])))

mapRet["identification"] = (int( ord(packet[4])>>8 )) + (int( ord(packet[5])))

mapRet["id"] = int(ord(packet[6]) & 0xE0)>>5

mapRet["fragOff"] = int(ord(packet[6]) & 0x1F)<<8 + int(ord(packet[7]))

mapRet["ttl"] = int(ord(packet[8]))

mapRet["protocol"] = int(ord(packet[9]))

mapRet["checkSum"] = int(ord(packet[10])<<8)+int(ord(packet[11]))

mapRet["srcaddr"] = "%d.%d.%d.%d" % (int(ord(packet[12])),int(ord(packet[13])),int(ord(packet[14])), int(ord(packet[15])))

mapRet["dstaddr"] = "%d.%d.%d.%d" % (int(ord(packet[16])),int(ord(packet[17])),int(ord(packet[18])), int(ord(packet[19])))

return mapRet

调用代码:

复制代码 代码如下:

proto = socket.getprotobyname('tcp') # only tcp

sock = socket.socket(socket.AF_INET, socket.SOCK_RAW, proto)

while True:

packet = sock.recvfrom(65535)[0]

if len(packet) == 0:

sck.close()

else:

#print str(packet)

mapIpTmp = decodeIpHeader(packet)

for k,v in mapIpTmp.items():

print k,"t:t",v

print ""

【python基础教程之获取本机ip数据包示例】相关文章:

python多线程http下载实现示例

python 获取文件列表(或是目录例表)

python多线程扫描端口示例

python根据距离和时长计算配速示例

python字符串替换示例

python基础教程之实现石头剪刀布游戏示例

python用字典统计单词或汉字词个数示例

python 获取本机ip地址的两个方法

python转换摩斯密码示例

python实现保存网页到本地示例

精品推荐
分类导航