我有一个针对Unix系统的traceroute Python程序,它打印出数据包从本地计算机到达目的地所需的路径 - 即数据包通过的路由器序列。问题是我得到一个输出显示:
traceroute to yahoo.co.in (68.180.206.184), 30 hops max, 60 byte packets
1 * * *
2 * * *
3 * * *
4 * * *
5 * * *
6 * * *
7 * * *
8 * * *
9 * * *
.
.
.
30 * * *
我有DSL连接。该程序适用于Windows命令行(cmd.exe)。上述输出的确切原因是什么?
代码如下所示:
#!/usr/bin/python
import socket
def main(dest_name):
dest_addr = socket.gethostbyname(dest_name)
port = 33434
max_hops = 30
icmp = socket.getprotobyname('icmp')
udp = socket.getprotobyname('udp')
ttl = 1
while True:
recv_socket = socket.socket(socket.AF_INET, socket.SOCK_RAW, icmp)
send_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, udp)
send_socket.setsockopt(socket.SOL_IP, socket.IP_TTL, ttl)
recv_socket.bind(("", port))
send_socket.sendto("", (dest_name, port))
curr_addr = None
curr_name = None
try:
_, curr_addr = recv_socket.recvfrom(512)
curr_addr = curr_addr[0]
try:
curr_name = socket.gethostbyaddr(curr_addr)[0]
except socket.error:
curr_name = curr_addr
except socket.error:
pass
finally:
send_socket.close()
recv_socket.close()
if curr_addr is not None:
curr_host = "%s (%s)" % (curr_name, curr_addr)
else:
curr_host = "*"
print "%d\t%s" % (ttl, curr_host)
ttl += 1
if curr_addr == dest_addr or ttl > max_hops:
break
if __name__ == "__main__":
main('yahoo.co.in')**
答案 0 :(得分:2)
traceroute / tracert在Linux和Windows上的行为方式不同。
Linux将发送一个TTL递减的UDP数据包并侦听ICMP响应。 Windows发送ICMP回应请求并侦听ICMP响应。
Python版本失败,因为UDP数据包被阻止。
在类Unix操作系统上,默认情况下traceroute实用程序使用目标端口号为33434到33534的用户数据报协议(UDP)数据报.traceroute实用程序通常有一个选项来指定使用ICMP echo请求(类型8)相反,正如Windows tracert实用程序所使用的那样。