用c语言编程帧的解析,封装,发送,Linux BSD Socket编程实现以太帧的捕获与分析

本文介绍了如何在Linux环境下使用C语言编程捕获和分析以太网数据帧,包括设置套接字监听链路帧、解析帧头信息、定位IP和TCP报头,以及分析应用层报文数据。通过设置网卡为混杂模式,利用SOCK_PACKET套接字捕获网络数据,并展示了如何处理捕获到的帧信息。
摘要由CSDN通过智能技术生成

转自:http://nking.blog.sohu.com/141551979.html

编程背景材料:

一、Linux下C语言编程环境介绍

1、使用gedit编辑器输入程序代码

(1)

单击“主菜单”(桌面左下方的图标)—>“附件”->“文本编辑器”,进入gedit编辑界面,输入程序。

(2) 保存文件的方法与MS

Windows中类似,注意保存位置,建议将保存位置设为:/home,文件名为:file.c。

2、使用gcc编译器

在桌面上单击右键,选择“新建终端”,弹出一对话框,在命令提示符#后依次输入:

# cd /home //进入程序所在目录

# ls //显示该目录下的文件及文件夹(应能见到file.c)

# gcc –g –o file file.c (例如

# gcc –g –o example example.c )

//编译程序

# ./file (例如 # ./example) //执行程序

二、 监听的实施

以太网上进行数据传输时http://www.airmaxshoe.net,在同一网段上连接的所有网卡事实上都可以收到在共享的物理介质上传输的所有数据。但在系统正常工作时,某个主机的网络接口只响应两种数据帧:一是帧的目标MAC地址与本主机网卡地址相符的帧;

二是帧的目标地址是广播地址的帧,除此之外的数据帧都将被丢弃不作处理。要监听流经网卡的不属于自己主机的数据,必须绕过系统正常工作的处理机制,直接访问网络底层。

三、 以太网数据帧、IP数据报、TCP首

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值