7

我找到了以下 tun\tap 示例程序,但无法使其工作:

http://www.secdev.org/projects/tuntap_udp/files/tunproxy.py

我修改了以下几行:

f = os.open("/dev/tun0", os.O_RDWR)
ifs = ioctl(f, TUNSETIFF, struct.pack("16sH", "toto%d", TUNMODE))
ifname = ifs[:16].strip("\x00")

修改了第一行以反映驾驶员的真实位置。它原本是

f = os.open("/dev/net/tun", os.O_RDWR)

运行时出现以下错误:

 sudo ./tuntap.py -s 9000
 Password:
 Traceback (most recent call last):
   File "./tuntap.py", line 65, in <module>
     ifs = ioctl(f, TUNSETIFF, struct.pack("16sH", "toto%d", TUNMODE))
 IOError: [Errno 25] Inappropriate ioctl for device

我正在使用从http://tuntaposx.sourceforge.net/download.xhtml安装的最新 tun\tap 驱动程序

4

2 回答 2

8

OSX tun/tap 驱动程序似乎有点不同。Linux 示例动态分配了一个 tun 接口,这在 OSX 中不起作用,至少以不同的方式。

我剥离了代码以创建一个基本示例,说明如何使用自选 tun 设备在 OSX 上使用 tun,将每个数据包打印到控制台。我添加了Scapy作为漂亮打印的依赖项,但如果需要,您可以将其替换为原始数据包转储:

import os, sys
from select import select
from scapy.all import IP

f = os.open("/dev/tun12", os.O_RDWR)
try:
    while 1:
        r = select([f],[],[])[0][0]
        if r == f:
            packet = os.read(f, 4000)
            # print len(packet), packet
            ip = IP(packet)
            ip.show()
except KeyboardInterrupt:
    print "Stopped by user."

您要么必须以 root 身份运行它,要么执行 asudo chown your_username /dev/tun12以被允许打开设备。

要将其配置为点对点接口,请键入:

$ sudo ifconfig tun12 10.12.0.2 10.12.0.1

请注意,该tun12界面仅在/dev/tun12打开时可用,即在程序运行时。如果你中断程序,你的tun界面就会消失,下次运行程序时需要重新配置。

如果您现在 ping 您的端点,您的数据包将被打印到控制台:

$ ping 10.12.0.1

Ping 本身将打印请求超时,因为没有隧道端点响应您的 ping 请求。

于 2013-02-28T15:46:15.927 回答
2

所以关于“没有这样的文件或目录”的错误:

f = os.open("/dev/tun12", os.O_RDWR)

这对我有用:

brew install Caskroom/cask/tuntap

于 2016-12-28T17:54:54.547 回答