- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Linux 上,可以使用 AF_PACKET 创建一个套接字,以从套接字接收原始数据并在应用程序中进行 IP 过滤。但是 OSX 的手册页没有这个:
PF_LOCAL Host-internal protocols, formerly called PF_UNIX,
PF_UNIX Host-internal protocols, deprecated, use PF_LOCAL,
PF_INET Internet version 4 protocols,
PF_ROUTE Internal Routing protocol,
PF_KEY Internal key-management function,
PF_INET6 Internet version 6 protocols,
PF_SYSTEM System domain,
PF_NDRV Raw access to network device
最佳答案
没有任何协议(protocol)是 POSIX 标准。 POSIX 根本不需要系统支持任何特定的网络协议(protocol)或任何网络协议(protocol)。AF_PACKET
是一个纯 Linux 发明 AFAIK,你不会在其他系统上找到它。
BPF(伯克利包过滤器)也不是 POSIX,它是许多系统复制的 BSD 发明,因为它非常方便。但是,您不能使用它注入(inject)流量,您只能使用它捕获传入和传出流量。
如果有人关心,这里是最新的 POSIX 标准:
The Open Group Base Specifications Issue 7, 2018 edition
IEEE Std 1003.1™-2017 (Revision of IEEE Std 1003.1-2008)
如果你真的想发送原始 IP 数据包(无论是 IPv4 还是 IPv6),使用原始 IP 套接字是最便携的:
int soc = socket(PF_INET, SOCK_RAW, IPPROTO_IP);
然后你需要告诉系统你想提供你自己的IP头:
int yes = 1;
setsockopt(soc, IPPROTO_IP, IP_HDRINCL, &yes, sizeof(yes));
现在您可以将原始 IP 数据包(例如 IP header + UDP header + 有效负载数据)发送到套接字进行发送,但是,根据您的系统,系统将执行一些健全性检查,并且可能会覆盖 header 中的某些字段。例如。它可能不允许您创建格式错误的 IP 数据包或阻止您执行 IP 地址欺骗。因此,它可能会为您计算 IPv4 header 校验和,或者如果您的 IP header 使用
0.0.0.0
,则自动填写正确的源地址。或
::
作为源地址。查看
ip(4)
的手册页或
raw(7)
在您的目标系统上。 Apple 不再提供 macOS 的程序员手册页,但
you can find them online.
Unlike previous BSD releases, the program must set all the fields ofthe IP header, including the following:
ip->ip_v = IPVERSION;
ip->ip_hl = hlen >> 2;
ip->ip_id = 0; /* 0 means kernel set appropriate value */
ip->ip_off = offset;
ip->ip_len = len;Note that the
ip_off
andip_len
fields are in host byte order.If the header source address is set to
INADDR_ANY
, the kernel willchoose an appropriate address.
ip_sum
根本没有提到,所以显然你不必提供那个,系统总是会为你计算它。
┌───────────────────────────────────────────────────┐
│IP Header fields modified on sending by IP_HDRINCL │
├──────────────────────┬────────────────────────────┤
│IP Checksum │ Always filled in │
├──────────────────────┼────────────────────────────┤
│Source Address │ Filled in when zero │
├──────────────────────┼────────────────────────────┤
│Packet ID │ Filled in when zero │
├──────────────────────┼────────────────────────────┤
│Total Length │ Always filled in │
└──────────────────────┴────────────────────────────┘
IPPROTO_IP
而不是
IPPROTO_RAW
.使用
IPPROTO_RAW
时您不必设置
IP_HDRINCL
:
A protocol of
IPPROTO_RAW
implies enabledIP_HDRINCL
and is able tosend any IP protocol that is specified in the passed header.
IPPROTO_RAW
对于传出流量:
An
IPPROTO_RAW
socket is send only.
IPPROTO_IP
您将收到所有 IP 数据包,但在 Linux 上这可能不起作用,因此创建了一个新套接字
PF_PACKET
socket 类型。应该在两个系统上工作的是指定一个子协议(protocol):
int soc = socket(PF_INET, SOCK_RAW, IPPROTO_UDP);
当然,现在您只能通过该套接字发送/接收 UDP 数据包。如果设置
IP_HDRINCL
同样,您需要在发送时提供完整的 IP header ,并且您将在接收时收到完整的 IP header 。如果你不设置它,你可以只在发送时提供UDP头,系统会自己添加一个IP头,也就是说,如果套接字是连接的并且可以选择绑定(bind),那么系统就知道在那个头中使用哪些地址.对于接收该选项不起作用,您总是会为您在此类套接字上收到的每个 UDP 数据包获取 IP header 。
PF_INET
而不是
AF_INET
: PF 表示协议(protocol)族,AF 表示地址族。通常这些是相同的(例如
AF_INET == PF_INET
)所以你使用什么并不重要,但严格来说应该使用
PF_
创建套接字和家人在
sockaddr
结构应设置为
AF_
有一天可能会有一种协议(protocol)支持两种不同的地址,然后会有
AF_XXX1
和
AF_XXX2
并且两者都不能与
PF_XXX
相同.
关于macos - OSX 上的 AF_PACKET,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17169298/
我带着为 OSX 编写 PAM 模块的永无休止的传奇再次回来了。我已经写好了模块。它在使用 ssh 或启动新的终端窗口或 su 时有效。我真正真正想要的只是 ssh 和登录窗口。 我的 PAM 模块在
我们有一个类似于Soundflower的虚拟音频设备驱动程序。该虚拟设备将在声音系统首选项中列出。每当我们的设备在系统偏好设置中被选择时,它就会阻止空闲 sleep 。如果我们将选择切换为默认输出设备
我带着为 OSX 编写 PAM 模块的永无止境的传奇又回来了。我已经编写了模块。它在使用 ssh 或启动新的终端窗口或 su 时有效。我真的、真的、真的想要的只是 ssh 和登录窗口。 我的 PAM
我想在 osx lion 上安装 pyaudio,但我无法做到。每次我尝试使用 pkg 时,它都不会安装任何东西。当我尝试使用 pip 安装它时,出现以下错误(以及许多其他行): lipo: can'
我使用 Java 进行开发已有很长时间了,但直到最近才从 Windows 切换到 OSX。在 Windows 中,我发现一切都足够简单易懂。我可以将 JDK 安装到一个选择的位置,其中还包括一个 JR
运行 Mac OSX 10.7.5 我想在 USB3 外部硬盘上启用 NTFS 并需要 UUID 来执行此操作( http://ntfsonmac.com ),但 diskutil 拒绝给我 UUID
我正在尝试为 Finder 创建服务,但我的应用程序不需要有 UI。好吧,我只需要一个 UI 来请求用户提供更多信息,我的应用程序有时可能需要这些信息。 但是应用程序应该在没有任何 UI 且 Dock
我正在尝试在我的 mac 上使用本地服务器,但它似乎忽略了/etc/hosts 文件中的 localhost 设置。找到了几个页面,其中解决方案是重新安装,并将 localhost 放在/etc/ho
这是一个 OSX 链接器问题。我不认为 OSX(BSD 或 Mach 层)在乎零页有多大,或者它是否真的存在。我认为这是一个工具的事情。但这是我的意见,这就是我问的原因。 -pagezero_size
我正在构建一个将在 iOS/OSX 应用中使用的模块。 客户坚持认为该模块可以在 iOS 和 OSX 上运行。 我需要检查我在 iOS 和 OSX 上使用 UIDevice 时使用的系统版本 FTWD
我尝试在 OSX 10.8.2 中使用 gnuplot,并看到 x11 是不明确或未知的终端类型。一些研究表明 x11 不受支持,我下载了 XQartz,但我仍然收到相同的错误消息。 我使用 expo
我从官方网站下载了 PostgreSQL 并运行了 .dmg 安装程序。之后我下载了 pgadmin3,我确实能够连接到数据库。 当我运行“psql”时,出现以下错误: psql: could not
自从升级到 OSX Catalina 以来,我一直遇到 UnsatisfiedLinkErrors 问题,尝试在 java 下运行 JNI 包装的库,其中包含多个 native 库引用,这些引用在早期
在 OSX 10.6 上使用 make 构建 C++ 项目时,我确定预处理器定义 __LP64__ 似乎始终自动由编译器(即,它没有在任何头文件中定义)(参见 Where is __LP64__ de
我正在尝试将我的 iOS 应用程序移植到 Mac OS X SDK,并且发现我收到以下错误消息:'Collection' redeclared as a different kind of symbo
我一直在 OSX 10.14 中成功使用我的代码生成 Metal 纹理: let textureLoaderOptions = [MTKTextureLoader.Option.origin : MT
我对编码有些陌生,想用 MySQL 后端启动我的第一个 Django 应用程序。我已经在我的 Windows 机器上使用这个设置将近一年了,但它是一个继承的代码库——不幸的是,我从未尝试过从头开始构建
我正在迁移到一台新计算机,同时从雪豹迁移到狮子。 phpunit 似乎没有进行迁移,所以我重新安装了它。然而,pear 的标准安装似乎不适用于我的 php 家庭brew 安装。这是错误: phpuni
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 已关闭 7 年前。 Improve
我在 OSX10.9 上为我的应用程序构建了一个 Java 7 bundle ,一切看起来都很好,但是当我在 OSX 10.7 上尝试它时,它在启动时崩溃,它已经在 10.7.3 和 10.7.5 上
我是一名优秀的程序员,十分优秀!