读取网络抓包文件data得到参数

本文介绍了一个程序,用于从data文件中读取网络抓包数据,解析Ethernet和IP头部信息,包括MAC地址、上层协议类型、IP头部各项参数,并进行校验。程序使用C++实现,涉及了数据结构、网络协议和文件操作。
摘要由CSDN通过智能技术生成
#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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值