linux内核打印数据包,打印TCP数据包数据

本文介绍了一个Linux内核模块示例,用于在接收到TCP数据包时打印其有效负载。通过修改内核模块,可以在POST_ROUTING阶段跟踪传出数据包。示例代码展示了如何注册Netfilter钩子并在HTTP流量上操作,打印源和目标地址、端口以及数据包数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如何从TCP数据包打印数据

下面是一个完全满足您需求的示例:挂钩接收TCP数据包并打印其有效负载.如果要从接收的数据包中打印一些其他信息(如二进制数据),您只需要修改此注释下的部分:

/ * —–从收到的TCP数据包中打印所有需要的信息—— * /

如果您需要跟踪传输的数据包而不是接收的数据包,则可以替换此行:

nfho.hooknum = NF_INET_PRE_ROUTING;

这一个:

nfho.hooknum = NF_INET_POST_ROUTING;

保存下一个文件并发出make命令来构建内核模块.然后执行sudo insmod print_tcp.ko加载它.之后,您将能够使用dmesg命令查看嗅探信息.如果要卸载模块,请运行sudo rmmod print_tcp命令.

print_tcp.c:

#include

#include

#include

#include

#include

#define PTCP_WATCH_PORT 80 /* HTTP port */

static struct nf_hook_ops nfho;

static unsigned int ptcp_hook_func(const struct nf_hook_ops *ops,

struct sk_buff *skb,

const struct net_device *in,

const struct net_device *out,

int (*okfn)(struct sk_buff *))

{

struct iphdr *iph; /* IPv4 header */

struct tcphdr *tcph; /* TCP header */

u16 sport, dport; /* S

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值