报文编程实现发送icmp协议详情大数据包

数据包mtu  时间:2021-04-19  阅读:()

实用文档

ICMP原理与代码及分析

专业

班级

学号

姓名

标准文案

一、 ICMP协议简介

ICMP全称Internet Control Message Protocol  中文名为因特网控制报文协议。它工作在 OSI的网络层向数据通讯中的源主机报告错误。 ICMP可以实现故障隔离和故障恢复。 网络本身是不可靠的在网络传输过程中可能会发生许多突发事件并导致数据传输失败。 网络层的 IP协议是一个无连接的协议它不会处理网络层传输中的故障而位于网络层的 ICMP协议却恰好弥补了 IP的缺限它使用 IP协议进行信息传递 向数据包中的源端节点提供发生在网络层的错误信息反馈。 ICMP的报头长 8字节结构如图 1所示。

比特0 7 8 15 16 比特31

图 1 ICMP报头结构

类型标识生成的错误报文它是 ICMP报文中的第一个字段

代码进一步地限定生成 ICMP报文。该字段用来查找产生错误的原因

校验和存储了 ICMP所使用的校验和值。

未使用保留字段供将来使用起值设为 0

数据包含了所有接受到的数据报的 IP报头。还包含 IP数据报中前 8个字节的数据

ICMP协议提供的诊断报文类型如表 1所示。

表1 ICMP诊断报文类型

ICMP提供多种类型的消息为源端节点提供网络层的故障信息反馈它的报文类型可以归纳为以下 5个大类

诊断报文类型 8代码0类型0代码0 

目的不可达报文类型 3代码0-15  

重定向报文类型 5代码0-4 

超时报文类型 1 1 代码0-1  

信息报文类型 12-18  。

二、编程实现发送 ICMP协议数据包

代码功能实现发送 ICMP协议数据包从而实现 DOS下ping命令功能。

1 .代码简要分析

代码执行步骤

 1  创建协议类型为 IPPROTO_ICMP的原始套接字设置套接字的属性。

2 创建并初始化ICMP封包。

3 调用sendto函数向远程主机发送 ICMP的请求。

4 调用recvfrom函数接受I CM P响应。

初始化ICMP头时先初始化消息的类型和代码域 之后应该是回显请求头。 程序首先定义了 ICMP头的数据结构 ICMP_HDR。typedef struct icmp_hdr

{unsigned char icmp_type; // 消息类型unsigned char icmp_code; //代码unsigned short icmp_checksum; //校验和

//下面是回显头unsigned short icmp_id; //用来惟一标识此请求的 ID号通常设置为进程 IDunsigned short icmp_sequence; //序列号unsigned long icmp_timestamp; // 时间戳

} ICMP_HDR, *PICMP_HDR;

2.完整代码及解析

#include". ./common/initsock.h"

#include". ./common/protoinfo.h"

#include". ./common/comm.h"

#include<stdio.h>

CInitSock theSock;typedef struct icmp_hdr

{unsigned char icmp_type; // 消息类型unsigned char icmp_code; //代码unsigned short icmp_checksum; //校验和

//下面是回显头unsigned short icmp_id; //用来惟一标识此请求的 ID号通常设置为进程 IDunsigned short icmp_sequence; //序列号unsigned long icmp_timestamp; // 时间戳

} ICMP_HDR, *PICMP_HDR;int main()

{

// 目的IP地址 即要Ping的IP地址char szDestIp[]="192.168.1 .104"; // 127.0.0.1

// 创建原始套节字

// 设置接收超时

SetTimeout(sRaw, 1000,TRUE);

// 设置目的地址

SOCKADDR_IN dest;dest.sin_fami ly=AF_I NET;dest.sin_port=htons(0);dest.sin_addr .S_un.S_addr=inet_addr(szDestIp);

// 创建ICMP封包char buff[sizeof(ICMP_HDR)+32];

ICMP_HDR*pIcmp=(ICMP_HDR*)buff;

// 填写ICMP封包数据pIcmp->icmp_type=8; //请求一个 ICMP回显pIcmp->icmp_code=0;pIcmp->icmp_id=(USHORT): :GetCurrentProcessId();pIcmp->icmp_checksum=0;pIcmp->icmp_sequence=0;

// 填充数据部分可以为任意memset(&buff[sizeof(ICMP_HDR)], 'E',32);

// 开始发送和接收 ICMP封包

USHORT nSeq=0;char recvBuf[1024];

SOCKADDR_IN from;int nLen=sizeof(from);whi le(TRUE)

{static int nCount=0;int nRet;if(nCount++==4)break;pIcmp->icmp_checksum=0;pIcmp->icmp_timestamp=: :GetTickCount();pIcmp->icmp_sequence=nSeq++;pIcmp->icmp_checksum=checksum((USHORT*)buff, sizeof(ICMP_HDR)+32);nRet=: :sendto(sRaw,buff,sizeof(ICMP_HDR)+32,0, (SOCKADDR*)&dest,sizeof(dest));if(nRet==SOCKET_ERROR)

{printf("sendto() fai led:%d\n", : :WSAGetLastError());return-1;

}

n Ret=: :recvfrom(sRaw, recvBuf, 1024, 0, (sockaddr*)&from,&nLe n);if(nRet==SOCKET_ERROR)

{if(: :WSAGetLastError()==WSAETI M EDOUT)

{printf(" timed out\n");conti nue;

}printf(" recvfrom() fai led:%d\n", : :WSAGetLastError());return-1;

}

// 下面开始解析接收到的 ICMP封包int nTick=: :GetTickCount();if(nRet<sizeof(I PHeader)+sizeof(ICMP_HDR))

{printf("Too few bytes from%s\n", : : inet_ntoa(from.sin_addr));

}

//接收到的数据中包含 IP头 IP头大小为 20个字节所以加 20得到ICMP头

ICMP_HDR* pRecvIcmp =(ICM P_HDR*)(recvBuf +

20); //(ICM P_HDR*)(recvBuf +sizeof(IPHeader));if(pRecvIcmp->icmp_type!=0) // 回显

{printf("nonecho type%d recvd\n", pRecvIcmp->icmp_type);return-1;

}if(pRecvIcmp->icmp_id !=: :GetCurrentProcessId())

{printf("someone else's packet! \n");return-1;

}printf("%d bytes from%s:", nRet, inet_ntoa(from.sin_addr));printf(" icmp_seq=%d. ", pRecvIcmp->icmp_sequence);printf(" time:%d ms", nTick-pRecvIcmp->icmp_timestamp);printf(" \n");

: :Sleep(1000);

}return 0;

}

三、代码结果分析

运行代码结果 源地址 192.168.1 .101 目的地址 192.168.1 .104 

由图可以分析出代码实现功能与 ping命令功能类似。 即代码会构建一个固定格式的 ICMP请求数据包然后由 ICMP协议将这个数据包连同地址 “192.168.1 .104 ”一起交给IP层协议 IP层协议将以地址

“ 192.168.1 .104作为目”的地址本机IP地址192.168.1 .101作为源地址加上一些其他的控制信息构建一个IP数据包并想办法得到192.168.1.104的MAC地址物理地址这是数据链路层协议构

建数据链路层的传输单元 ——帧所必需的  以便交给数据链路层构建一个数据帧。关键就在这里 IP层协议通过机器 B的IP地址和自己的子网掩码 发现它跟自己属同一网络 就直接在本网络内查找这台机器的MAC,如果以前两机有过通信在 A机的ARP缓存表应该有 B机I P与其MAC的映射关系如果没有就发一个 ARP请求广播得到 B机的MAC,一并交给数据链路层。后者构建一个数据帧目的地址是IP层传过来的物理地址源地址则是本机的物理地址还要附加上一些控制信息依据以太网的介质访问规则将它们传送出去。

主机B收到这个数据帧后先检查它的目的地址并和本机的物理地址对比如符合则接收否则丢弃。接收后检查该数据帧将 IP数据包从帧中提取出来交给本机的 IP层协议。 同样 IP层检查后将有用的信息提取后交给 ICMP协议后者处理后马上构建一个 ICMP应答包发送给主机 A其过程和主机 A发送ICMP请求包到主机 B一模一样。

由wireshark 抓包我们可以更清楚的看到两者的相似处。

Wireshark抓到代码的数据包 源地址 192.168.1 .101 目的地址 192.168.1 .104 

OneTechCloud(31元),美国CN2 GIA高防VPS月

OneTechCloud发布了本月促销信息,全场VPS主机月付9折,季付8折,优惠后香港VPS月付25.2元起,美国CN2 GIA线路高防VPS月付31.5元起。这是一家2019年成立的国人主机商,提供VPS主机和独立服务器租用,产品数据中心包括美国洛杉矶和中国香港,Cera的机器,VPS基于KVM架构,采用SSD硬盘,其中美国洛杉矶回程CN2 GIA,可选高防。下面列出部分套餐配置信息。美国CN...

RAKsmart含站群服务器/10G带宽不限流量首月半价

RAKsmart 商家估摸着前段时间服务器囤货较多,这两个月的促销活动好像有点针对独立服务器。前面才整理到七月份的服务器活动在有一些配置上比上个月折扣力度是大很多,而且今天看到再来部分的服务器首月半价,一般这样的促销有可能是商家库存充裕。比如近期有一些服务商挖矿服务器销售不好,也都会采用这些策略,就好比电脑硬件最近也有下降。不管如何,我们选择服务器或者VPS主机要本着符合自己需求,如果业务不需要,...

无忧云:服务器100G高防云服务器,bgpBGP云,洛阳BGP云服务器2核2G仅38.4元/月起

无忧云怎么样?无忧云值不值得购买?无忧云,无忧云是一家成立于2017年的老牌商家旗下的服务器销售品牌,现由深圳市云上无忧网络科技有限公司运营,是正规持证IDC/ISP/IRCS商家,主要销售国内、中国香港、国外服务器产品,线路有腾讯云国外线路、自营香港CN2线路等,都是中国大陆直连线路,非常适合免备案建站业务需求和各种负载较高的项目,同时国内服务器也有多个BGP以及高防节点。目前,四川雅安机房,4...

数据包mtu为你推荐
利用安卓智能手机探究浓度对化学平衡的影响徐州微信5深圳做网站-确认收货手太快网店发来空箱子平板ipad杭州市西湖区翠苑第四幼儿园智慧校园采购项目支持ipad支持ipadeaccelerator开启eAccelerator内存优化就各种毛病,DZ到底用哪个内存优化比较好。。。win10关闭445端口在win10 如何关闭445端口的最新相关信息ms17-010win10蒙林北冬虫夏草酒·10年原浆1*6 500ml 176,176是一瓶的价格还是一箱的价格
php网站空间 qq域名邮箱 域名商 新加坡主机 联通c套餐 gitcafe 主机屋免费空间 godaddy优惠券 京东云擎 lighttpd 免费ftp站点 韩国网名大全 警告本网站美国保护 52测评网 vip购优汇 绍兴电信 搜索引擎提交入口 流媒体加速 江苏双线服务器 闪讯官网 更多