python的dpkt库

           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进制转储


posted @ 2009-11-02 19:31  doujiu  阅读(2707)  评论(0编辑  收藏  举报