12

我按照网页http://www.tenouk.com/Module43a.html编写了一个 rawudp 程序来通过原始套接字发送 udp 数据包。然后我写了一个 udp 服务器来监听给定端口上的 udp 数据包。代码如下所示:

...
sd = socket(AF_INET, SOCK_DGRAM, 0);
bind(sd, (struct sockaddr *)&ipaddr, sizeof(ipaddr));
size = recvfrom(sd, msgbuf.text, 2000, 0, (struct sockaddr *)&sin, &sin_len);
... // print the recevied udp packet

当我使用rawudp向udp服务器发送udp数据包时,如果源ip地址和目的ip地址不同就可以了。但是如果源ip地址和目的ip地址相同,udp服务器就收不到udp数据包。

我尝试使用 tcpdump 来捕获 udp 数据包。我发现 tcpdump 可以在使用相同的源和目标 IP 地址时显示 udp 数据包。似乎当源IP地址和目标IP地址相同时,udp数据包在某处被丢弃,因此udp服务器中的套接字没有收到它。

以下是一些日志(IP 地址已在日志中更新)。两种情况之间的唯一区别是源 IP 地址(192.168.0.26 与 192.168.0.226)。

我被困在这个问题上。有没有人可以帮助我。提前致谢。

udp 客户端(rawudp):

case 1> rawudp 192.168.0.26 18321 192.168.0.226 19702 test.bin # using different source and destination ip addresses
size of ip header:  20
size of udp header: 8
read 69 bytes from file test.bin successfully.
socket() - using SOCK_RAW socket and UDP protocol is OK.
setsockopt() is OK.
total length of IP packet: 97
    0000:  4500 6100 0000 4000 4011 CD8F C0A8 001A 
    0010:  C0A8 00E2 4791 4CF6 004D 0000 0104 0401 
    0020:  FF00 0105 084E 0600 5225 1183 0406 0501 
    0030:  5211 3840 0D05 2735 2109 02C0 0023 0101 
    0040:  8080 448D 30C0 0300 9005 093C 5E56 8791 
    0050:  4B2D B7C0 082A 0000 2900 0000 0412 0C95 
    0060:  00
sendto() is OK.

case 2> rawudp 192.168.0.226 18321 192.168.0.226 19702 test.bin # using same source and destination ip addresses
size of ip header:  20
size of udp header: 8
read 69 bytes from file test.bin successfully.
socket() - using SOCK_RAW socket and UDP protocol is OK.
setsockopt() is OK.
total length of IP packet: 97
    0000:  4500 6100 0000 4000 4011 CCC7 C0A8 00E2 
    0010:  C0A8 00E2 4791 4CF6 004D 0000 0104 0401 
    0020:  FF00 0105 084E 0600 5225 1183 0406 0501 
    0030:  5211 3840 0D05 2735 2109 02C0 0023 0101 
    0040:  8080 448D 30C0 0300 9005 093C 5E56 8791 
    0050:  4B2D B7C0 082A 0000 2900 0000 0412 0C95 
    0060:  00
sendto() is OK.

udp服务器端:

case 1>
udp server receive 69 bytes from ip address 192.168.0.26 port 18321, sin_len 16
02:13:24.252841 IP 192.168.0.26.18321 > 192.168.0.226.19702: UDP, length 69
    0x0000:  4500 0061 0000 4000 4011 0198 c0a8 001a  E..a..@.@.......
    0x0010:  c0a8 00e2 4791 4cf6 004d 0000 0104 0401  ....G.L..M......
    0x0020:  ff00 0105 084e 0600 5225 1183 0406 0501  .....N..R%......
    0x0030:  5211 3840 0d05 2735 2109 02c0 0023 0101  R.8@..'5!....#..
    0x0040:  8080 448d 30c0 0300 9005 093c 5e56 8791  ..D.0......<^V..
    0x0050:  4b2d b7c0 082a 0000 2900 0000 0412 0c95  K-...*..).......
    0x0060:  00
                              .
02:13:39.500469 IP 192.168.0.226.18321 > 192.168.0.226.19702: UDP, length 69
    0x0000:  4500 0061 0000 4000 4011 00d0 c0a8 00e2  E..a..@.@.......
    0x0010:  c0a8 00e2 4791 4cf6 004d 0000 0104 0401  ....G.L..M......
    0x0020:  ff00 0105 084e 0600 5225 1183 0406 0501  .....N..R%......
    0x0030:  5211 3840 0d05 2735 2109 02c0 0023 0101  R.8@..'5!....#..
    0x0040:  8080 448d 30c0 0300 9005 093c 5e56 8791  ..D.0......<^V..
    0x0050:  4b2d b7c0 082a 0000 2900 0000 0412 0c95  K-...*..).......
    0x0060:  00        

当我在同一主机上运行 rawudp 和 udp 服务器时,当我将源 IP 地址和目标 IP 地址设置为相同时,upd 服务器可以接收来自 rawudp 的 udp 数据包。但是,如果我在与 udp 服务器不同的主机上运行 rawudp,当我将这些 IP 地址设置为相同时,udp 服务器无法接收来自 rawudp 的 upd 数据包。在这两种情况下,tcpdump 都可以在 udp 服务器端捕获 udp 数据包。

在后一种情况下,只有具有相同源和目标 IP 地址的 udp 数据包会受到影响。如果我将它们设置不同,upd 服务器总是可以接收 udp 数据包。lo如果未从接口接收到数据包,我不确定内核是否会丢弃具有相同本地 IP 地址的数据包。

4

0 回答 0