学习dpkt库-dpkt.py
最近在学习使用python进行网络编程。
本来使用c没问题的,但是python的语法太精练了,忍不住使用python了,这样就需要学习python前辈留下的许多强大的Lib库,其中之一就是dpkt。
先从入口程序看起:dpkt.py
dpkt定义了Packet类,这是所有其他dpkt定义的网络报文类型的基础类。Packet类继承自Object。
1、ip,icmp等等子类都继承自dpkt class,每个子类都会定义一个__hdr__结构,该结构代表报文的头结构,是一个元组,其中包含若干个元组。每个子元组的结构是:
(name, structfmt, default) ----(名称,结构格式,默认值)
类中有一个pack_hdr()函数负责对该数据进行打包。
举个例子:
>>> class Foo(Packet):
... __hdr__ = (('foo', 'I', 1), ('bar', 'H', 2), ('baz', '4s', 'quux'))
...
>>> foo = Foo(bar=3)
>>> foo
Foo(bar=3)
>>> str(foo)
'\x00\x00\x00\x01\x00\x03quux'
>>> foo.bar
3
>>> foo.baz
'quux'
>>> foo.foo = 7
>>> foo.baz = 'whee'
>>> foo
Foo(baz='whee', foo=7, bar=3)
>>> Foo('hello, world!')
Foo(baz=' wor', foo=1751477356L, bar=28460, data='ld!')
2、该类在初始化时接受可选参数:buf,keyword
buf:可以传入待解包的报文,一旦传入,则程序会自动调用unpack()函数进行解包
keyword:设置__hdr__的相关域的值
3、继承了__str__()函数,使得调用str()时,会进行如下操作:
return self.pack_hdr() + str(self.data)
4、hexdump()函数,可进行16进制转储。
如:dpkt.hexdump(str(ippack), 20) 每行处理20字节方式进行16进制转储