网络编程,捕获IP数据包

任务三 网络编程

1. IP数据报的格式说明:

IP数据包格式包含了标头固定部分,标头可变部分和数据区三部分。IP数据报标头部分固定为20个字节,其中包含了12个参数域,各参数域隐含着网间协议的传输机制。IP具体的标头格式如图1所示。
各字段的具体含义如下:

  1. 版本号:长度4位,表示所使用的IP协议的版本。IPv4版本号字段值为4;IPV6版本号字段号的值为6.
  2. 标头长:长度4位,定义了一个以4B为一个单位的IP包的报头长度
  3. 服务类型:共8位,高3位组成优先级子域,随后4位组成服务类型子域。
  4. 数据报总长度:总长度为2B(即6位)。定义了以字节为单位的数据报的总长度。
  5. 重装标识:长度16位,用于识别IP数据报的编号,让目的主机判断新来的数据属于哪个分组。
  6. 分片标识:共3位,最高位为0;DF禁止分片标识。DF=0,可以分片;DF=1,不能分片。MF:分片标识。MF=0,表示接的是最后一个分片;MF=1,不是最后一个分片。
  7. 片偏移值:共13位,说明分片在整个数据报中的相对位置。
  8. 生存周期:8位,用来设置数据数据报在整个网络传输过程中的寿命。常以一个数据报可以经过的最多的路由器跳步数来控制。
  9. 协议类型:共8位,表示该IP数据报的高层协议类型。
  10. 标头校验和:共16位,用于存放检查报头错误的校验码。
  11. 源、宿主机地址:共32位,分别表示发送和接受数据报的源主机和宿主机的IP地址。
  12. 选项数据域:0-40B,用于控制和测试。
    IP数据包的格式为:

在这里插入图片描述

2.实验软件及操作系统(VC6.0)

IP数据包的C++定义:
typedef struct _IP
{
union
{
BYTE Version; // 版本
BYTE HdrLen;//IHT
};
BYTE ServiceType; // 服务类型
WORD TotalLen; // 总长
WORD ID; // 标识
union
{
WORD Flags; // 标志
WORD FragOff; // 分段偏移
};
BYTE TimeToLive; // 生命期
BYTE Protocol; // 协议
WORD HdrChksum; // 头校验和
DWORD SrcAddr; // 源地址
DWORD DstAddr; // 目的地址
BYTE Options; // 选项
} IP;

套接字的使用:

本程序使用套接字socket编程,将网卡设为能够接受流经网卡的所有类型的数据包。首先,初始化套接字,然后监听数据包,解析数据包。
SOCKET sock=socket(AF_INET,SOCK_RAW,IPPROTO_IP)用来创建套接字,其参数为通信发生的区字段和套接字的类型。
WSAIoctl(sock , IO_RCVALL ,&dwBufferInLen , sizeof(dwBufferInLen)函数用来把网卡设置为混杂模式。
recv(sock,buffer,65535,0)函数用来接收经过的IP包,其参数分别是套接字描述符,缓冲区的地址,缓冲区的大小。

3.程序流程图
在这里插入图片描述

4.程序设计思想

①、使用原始套接字

要进行IP层数据包的接收和发送,应使用原始套接字。创建原始套接字的代码如下:
SOCKET sock;
sock=WSASoccket(AF_INET,SOCK_RAW,IPPROTO_IP,NULL,0,
WSA_FLAG_OVERLAPPED);

在WSASoccket函数中,第一个参数指定通信发生的区字段,AF_INE

评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值