首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从TCP程序(特别是TCP堆栈)截获(不仅仅是捕获)传出数据包?

如何从TCP程序(特别是TCP堆栈)截获(不仅仅是捕获)传出数据包?
EN

Server Fault用户
提问于 2013-05-07 17:57:39
回答 2查看 3.3K关注 0票数 -1

我有一个运行在主机上的web服务器,我希望拦截由web服务器发送的所有数据包(包括IP/TCP报头),因此这些数据包不会被web服务器直接发送到Internet。

最初,我的计划是使用iptable过滤web服务器发送的数据包,并使用libpcap捕获数据包。但我得知道包流是:

代码语言:javascript
复制
  Wire----NIC----libpcap----INPUT CHAIN---TCP STACK
  Wire----NIC----libpcap----OUTPUT CHAIN---TCP STACK

这意味着对于传入的数据包,我可以使用libpcap和iptables来实现拦截:使用libpcap来捕获数据包,使用iptables来阻止数据包传递到TCP堆栈。但是对于从web服务器截取出的数据包,libpcap和iptables的组合似乎不起作用。因为如果我过滤出的数据包,我的libpcap无法捕获这些数据包。如果我不使用iptable来过滤,尽管我可以使用libpcap捕获数据包,原始数据包将到达Internet。

我的目标是拦截从are服务器发送的所有数据包(包括TCP/IP报头),有什么解决方案吗?谢谢!

注意:我不是在问如何修改数据包TCP/IP报头,我只是让您知道我为什么要拦截数据包(包括IP/TCP报头)。我在问如何截取数据包。

EN

回答 2

Server Fault用户

回答已采纳

发布于 2013-05-08 00:33:31

使用libpcap来抓取包进行修改是错误的。您几乎可以肯定地看到了内置在netfilter中的一种方法,用于处理用户空间中的数据包。

如果您希望以未内置于netfilter中的方式修改或滥用数据包,那么您可能需要对NFQUEUE目标进行强检查。

这允许您设置规则,以便将数据包传递到用户空间。然后你可以做你想做的事,然后再注射。

如果您实际上不需要对数据包做任何事情,然后接受它,那么ULOG目标可能会提供您想要的东西。ULOG将整个数据包转发给用于日志记录的用户空间进程。

当然,您的另一个选项可能是构建您自己的netfilter模块来进行任何不寻常的数据包更改,如果没有一个内置的方法提供您所需要的。

票数 4
EN

Server Fault用户

发布于 2013-05-07 18:18:12

您可能希望将代理(如nginx或want )放在Apache前面。

这样就可以以适当的方式对Apache的响应进行按摩,而且这比在网络级别上做要容易得多。

票数 2
EN
页面原文内容由Server Fault提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://serverfault.com/questions/505730

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档