3

我正在尝试在 Python 中实现基于 ICMP 的 Traceroute。

我找到了一个非常有用的指南(https://blogs.oracle.com/ksplice/entry/learning_by_doing_writing_your),它允许我创建一个基于 UDP 的 Traceroute(下面的代码),所以只需要修改。我尝试将发送套接字更改为 ICMP,但是没有异常我无法运行任何东西。

注意 - 下面的代码有效,但是这是一个 UDP 跟踪路由(发送一个 UDP 数据包并接收一个 ICMP 数据包),我需要我的程序发送一个 ICMP 数据包并接收一个 ICMP 数据包。这是因为如今的防火墙比以前更智能,并且在接收到随机端口的 UDP 数据包后并不总是发送 ICMP 响应。本质上,UDP 套接字需要更改为 ICMP 套接字。

我想这不是最常见的尝试和实现的事情,并且在网上研究如何做到这一点时遇到了麻烦。如果有人可以提供一些见解,将不胜感激:-)

要记住的要点是,traceroutes 通过设置 TTL 来工作,所以如果解决方案是使用 ICMP 库,那么它需要有一个可配置的 TTL :-)

#!/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('google.com')
4

2 回答 2

3

这是使用 Scapy 的解决方案 - 感谢 KillianDS。

发送 ping

ans,unans=sr(IP(dst="www.google.com",ttl=X)/ICMP())

访问回复

ans.summary(lambda (s,r): r.sprintf("%IP.src%") )
于 2012-04-26T03:36:57.010 回答
0

如果您不想自己管理套接字,scapy是构建您自己的数据包并使用它们进行基本发送/接收的好工具。您可以在此处找到如何 ping 的示例,从此(并阅读一些文档)您应该能够非常轻松地构建自己的跟踪路由。

于 2012-04-21T11:08:38.343 回答