Chinaunix

标题: dhcp方面的问题 [打印本页]

作者: kallytin    时间: 2013-03-07 22:36
标题: dhcp方面的问题
本帖最后由 kallytin 于 2013-03-07 22:39 编辑

最近在写一些关于DHCP方面的东西,碰到一些问题,如下:

写程序实现发一个 DHCPDISCOVER 的包,成功收到DHCP服务器发回来的 DHCPOFFER。根据该数据包中的内容,我重新设置了DHCPREQUEST数据包里的选项部分:
1)根据DHCPOFFER数据包里的 client ip,我设置了DHCPREQUEST数据包里选项的 request ip(50)
2)根据DHCPOFFER数据包里的 dhcp server identifier,我设置了DHCPREQUEST数据包里选项的 dhcp server identifier(54)
3)将DHCPREQUEST数据包的信息类型设置为DHCP REQUEST(53-3)

此外,对于UDP头,设定如下:
1)source port        :68
2)dest port        :67

对于IP头,如下:
1)source ip        : 0.0.0.0
2)dest ip        : 255.255.255.255

对于frame头,如下:
1)source mac: 本端网卡的mac
2)dest mac    : ff.ff.ff.ff.ff.ff

======
问题:
======

捕捉到已发出DHCPREQUEST数据包,但一直得不到DHCP服务器方面的回应(DHCPACK)。请教一下各位大师,到底哪里设置错了 ?

======
注:
======
DHCP里的flag无论最高位是0或1(单播/广播),结果都是一样的(即目前这个情况)。
作者: kallytin    时间: 2013-03-07 22:57
回复 1# kallytin

ding..........
   
作者: ssffzz1    时间: 2013-03-08 10:44
最高位是0或1(单播/广播),结果都是一样,这个的确影响不大。


你抓个正常的DHCP报文比对下,你的那些字段搞错了。
作者: kallytin    时间: 2013-03-08 21:11
本帖最后由 kallytin 于 2013-03-08 21:13 编辑
ssffzz1 发表于 2013-03-08 10:44
最高位是0或1(单播/广播),结果都是一样,这个的确影响不大。


之前已尝试过抓包,逐个字段对过,都没问题............

现在,问题解决了,居然是dhcp server端需要进行udp checksum的测试。由于udp缺省是不进行checksum检验的,因此当我原来的包的udp检验码不对时,server就丢弃了该数据包。现在已改过来。挺隐蔽的错误..........

另外,对于DHCPRELEASE的数据包,需要怎样设置才能使server端解除client_ip与client_mac之间的绑定(即在收到DHCPRELEASE包后立即解除租约,让client_ip变得可让其他主机使用)?

我对DHCPRELEASE数据包的设定如下:

1)设置了DHCPRELEASE数据包里选项的 dhcp server identifier(54)
2)设置了DHCPRELEASE数据包里选项的 dhcp client identifier(61)
3)将DHCPRELEASE数据包的信息类型设置为DHCP RELEASE(53-7)
4)设置了DHCPRELEASE数据包里选项的 message(56),“clean shutdown”

此外,对于UDP头,设定如下:
1)source port        :68
2)dest port        :67

对于IP头,如下(采取单播):
1)source ip        : 本网卡IP
2)dest ip        : server端的IP

对于frame头,如下:
1)source mac: 本端网卡的mac
2)dest mac    : server端的mac

目前的结果是DHCPRELEASE数据包成功发出,但server端没任何回应。查看server端有关client_ip与client_mac之间的绑定(即租约),发现租约没有被取消。可见,DHCPRELEASE数据包并没有发挥作用。目前不太清楚DHCPRELEASE数据包什么地方设置错了。此外,由于调试环境所限,目前不能抓取DHCPRELEASE数据包(其他类型的数据包可以)。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2