#include <fstream>
#include <iostream>
#include <iomanip> //I/O流控制头文件
#include <WINSOCK2.H>
using namespace std;
struct eth_header //帧头
{
unsigned char eth_dst[6];
unsigned char eth_src[6];
unsigned short upper_pro; //上层协议 0800表示是ip数据包
};
struct ip_header //ip报头
{
union
{
unsigned char version; //版本
unsigned char ihl; //报头长度
};
unsigned char tos; //服务类型
unsigned short total_len; //总长度
unsigned short identifer; //标识
union
{
unsigned short flags; //标志
unsigned short offset; //片偏移
};
unsigned char TTL; //生存周期
unsigned char protocol; //协议
unsigned short checksum; //头部校验和
unsigned char ip_src[4]; //源ip地址
unsigned char ip_dst[4]; //目的ip地址
unsigned int option; //选项+填充
//数据
};
void main()
{
int temp[38]; //? why 38?
ifstream infile("D:\\data"); //打开文件
int i;
for (i
读取网络抓包文件data得到参数
最新推荐文章于 2023-10-08 11:44:30 发布
本文介绍了一个程序,用于从data文件中读取网络抓包数据,解析Ethernet和IP头部信息,包括MAC地址、上层协议类型、IP头部各项参数,并进行校验。程序使用C++实现,涉及了数据结构、网络协议和文件操作。
摘要由CSDN通过智能技术生成