# 这个脚本是实现Linux中traceroute程序的,是探测从我们这个机器到我们要探测的IP地址中间都需要经过那些路由。
# 原理:我们的机器发送UDP高端口的数据包,发送给目的地址,首先设置ttl为1,然后逐次增加,在没有到达我们的目的IP
# 地址的路由,会发送ICMP的超时报文,然后我们从中提取IP地址,因为我们发送的是高端口的报文,到达目的地址的时候,
# 目的地址会发送ICMP的端口不可达报文,这样我们就探测出从我们源端口到目的端口的路由。
from scapy.all import *
import struct,re,random
# 跟我们实现ping程序的想法是一样的,首先构造一个发送一个UDP报文的函数,
# 入参为目的地址,ttl数。
def traceroute_one(dst,ttl_no,dport):
# 定义发包时间。
send_time = time.time()
try:
# 发送一个包,接收一个包。
traceroute_one_reply = sr1(IP(dst=dst, ttl=ttl_no) / UDP(dport=dport) / b'hello world', timeout=1,
verbose=False)
# 判断ICMP包是不是超时回答。
if traceroute_one_reply.getlayer(ICMP).type == 11 and traceroute_one_reply.getlayer(ICMP).code ==