IP分片重组--IP_fenPian_chongZu--失败了原因--是memcpy(check,&ip,20)不是memset(check,&ip,20);分片时,出现乱码!!!---如何解决
// IP_fenPian_chongZu.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include//文件操作
#include
//#include//memset()用到
#include
#include//网络编程专用的
#pragma comment(lib,"ws2_32")//加载windows系统文件ws2_32.lib
using namespace std;//有她string才能用
typedef str...
分片时,出现乱码!!!---如何解决
// IP_fenPian_chongZu.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include
//文件操作
#include
//#include//memset()用到
#include
#include//网络编程专用的
#pragma comment(lib,"ws2_32")//加载windows系统文件ws2_32.lib
using namespace std;//有她string才能用
typedef struct IP_HEAD//定义储存IP头数据的结构体
{
union //联合体,里边的成员共用,空间,开空间大小为,其中的某个成员的类型对应最长的控件,如下面char类型最长,为1字节,即8位;version和headLen两个变量共用1个字节
{
unsigned char version; //"版本号"字段(用字节的前4位
记录
混凝土 养护记录下载土方回填监理旁站记录免费下载集备记录下载集备记录下载集备记录下载
);unsigned--无符号
unsigned char headLen; //IP数据包“头部的长度”字段(用字节的后4为记录);IP数据包 头部中 除了“选项”和“填充"字段外,其他个字段都是定长的。IP包头部的基本长度为20字节,如果加上最长40字节的“选项”字段,则,IP包头部最长为60字节.(20+40)
};
unsigned char serviceType; //”服务类型“,该字段长为8位,用来
表
关于同志近三年现实表现材料材料类招标技术评分表图表与交易pdf视力表打印pdf用图表说话 pdf
示路由器如何处理该数据包;该8位分成三部分:
/*
最高的3位表示优先级,用来说明IP数据包的重要性,优先级越高越重要,则路由器优先对他处理;
有高位到底位:111表示网络控制,110表示网络间控制,101表示重要(CRITIC/ECP),100表示即时优先,011表示即时,010表示立刻,001表示优先,000表示普通
*/
/*
中间4位表示服务类型,从高位到低位:D(延时)、 T(吞吐量)、 R(可靠性)、 C (成本);
DTRC:1111表示安全的最高级,1000表示延时最小,0100表示吞吐量最大,0010表示可靠性最大,0001表示成本最小,0000表示普通服务。
*/
//最低1位是保留位
unsigned short totalLen; //”总长度“字段,占16位;定义以字节为单位的IP数据包总长度;由于总长度字段的长度为16位,因此,IP数据包的最大长度=2的16次方-1=65535字节;数据部分的长度=总长度-头部长度;
unsigned short identifier;//”标识符“字段,长度16位,用来表示IP数据包的归属;每批IP数据包都需要有一个标识符,目的主机用来判断IP数据包属于哪一个服务
union
{
unsigned short flags;//”标志位“字段,(使用最高的3位);
//用来表示IP包是否可以分片;
//保留位、DF位、MF位:
// 最高位保留位为0,
//DF=0时,表示分片 ,DF=1时,表示不能对数据包分片;
//MF=1时,表示接收的不是最后一个分片,MF=0时,表示接收的是最后一个分片
unsigned short fragOffset;//"片偏移"字段,(使用低13位);用来表示分片在整个IP数据包中的相对位置
//片偏移值是以“8字节”为单位来计算,因此,分片的长度应该是“8字节”的整数倍
};
unsigned char timeToLive;//"生存周期"字段,长度为8位;
//用来表示IP数据包在传输过程中的寿命,通常用经过最多的路由器跳步数来限制
//IP数据包的传输延时是不确定的,为了避免由于路由表出错而循环传输,可以通过设置生存周期来解决这个问题
unsigned char protocol;//”
协议
离婚协议模板下载合伙人协议 下载渠道分销协议免费下载敬业协议下载授课协议下载
”字段,长度为8位,用来表示IP数据包的高层协议类型,如下,相应的值对应的协议:
//1--ICMP,2--IGMP,4--IP in IP,6--TCP,8--EGP,17--UDP,41--IPv6,46--RSVP,89--OSPF
unsigned short headChecksum;//“头部校验和”字段,长度为16位;
unsigned int sourceAddr; //源IP地址 ,发送IP包的源主机地址
unsigned int destinAddr; //目的IP地址,接收IP包的目的主机地址
//unsigned char options; //“选项”字段,长度为0~40个字节;
// 主要用于控制和测试这两个目的。在使用选项字段的过程中,有可能出现头部长度不为32位的整数倍的情况,这时就需要通过充位来凑齐
}ip_head;
//校验和计算
unsigned short checkSum(unsigned short *buffer,int size)
{
unsigned long cksum=0; //32位,不用16位,为了保留,16位相加时,最高位的进位
//先求和
while(size>1)
{
cksum+=*buffer++; //buffer是16位,每一次都是以16位长度加一次
size-=sizeof(unsigned short); //当size小于16位时,退出相加,下面else把不足16位的那部分单独处理
}
if(size)
{
cksum+=*(unsigned*)buffer;//把不足16位的那部分单独处理--先‘填充’满16位再加//无符号 短整型指针 强制转换为 无符号 字符型指针
}
//再把和取反,才得到想要的结果
cksum=(cksum>>16)+(cksum & 0xffff); //cksum的高16位+cksum的低16位//(32位的cksum的高16位移到低16位,而高16位被0填充)+(32位的cksum和16位的0xffff相与的结果);//32位的和16位的相与时,先将16位的扩展为32位,原先的16位做为扩展后的32位的低16位,高16位用0填充,实际意义就是,取cksum的低16位
cksum+=(cksum>>16); //说白了就是循环加;;把进位到高16位的1,加回到低16位,而且,首先把该高16位变为低16位,才能加
return (unsigned short)(~cksum); //~是二进制取反,最终所要的头部校验和
}
void main()
{
string intStr="E:\\infile.txt";
string outStr="E:\\outfile.txt";
fstream outFile;
outFile.open(outStr,ios::in|ios::out|ios::trunc);//ios::trunc将先前的文件内容移除ios::app 追加模式打开文件夹, 以ios::app打开,如果没有文件,那么生成空文件;如果有文件,那么在文件尾 追加
if(!outFile.is_open())
{
cout<<"无法打开文件!!"<
函数
excel方差函数excelsd函数已知函数 2 f x m x mx m 2 1 4 2拉格朗日函数pdf函数公式下载
memset(check,&ip,20);//?? ??&ip数据类型不对应???不容??
/*可以参考这种方式,而不用memcpy()
icmp_hdr->headChecksum=checkSum((unsigned short*)icmp_data,icmpsize);//只取MAX_PACKET的部分,即icmpsize=默认的数据包长度(32字节)+ICMP包头部长度(结构体总长度),这么多而已
*/
//check=&ip;
ip.headChecksum=checkSum(check,20);//计算校验和
cout<<"$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$"<>4 )<>5)<<" 服务类型(中间4位)--"<<((ip.serviceType>>1) & 0x0f)<>5)右移5位;((ip.serviceType>>1) & 0x0f),先右移1位,再相与运算,最后取得低4位
cout<<"总长度(=头部长度+数据部分长度)"<>15) & 0x01)<<" DF位(1表示不能对数据包分片,0表示可以分片)--"<<((ip.flags>>14) & 0x01)<<"MF位(1表示接收的不是最后一个分片,0表示接受的是最后一个分片)--"<<((ip.flags>>13) & 0x01)<//文件操作
#include
//#include//memset()用到
#include
#include//网络编程专用的
#pragma comment(lib,"ws2_32")//加载windows系统文件ws2_32.lib
using namespace std;//有她string才能用
typedef struct IP_HEAD//定义储存IP头数据的结构体
{
union //联合体,里边的成员共用,空间,开空间大小为,其中的某个成员的类型对应最长的控件,如下面char类型最长,为1字节,即8位;version和headLen两个变量共用1个字节
{
unsigned char version; //"版本号"字段(用字节的前4位记录);unsigned--无符号
unsigned char headLen; //IP数据包“头部的长度”字段(用字节的后4为记录);IP数据包 头部中 除了“选项”和“填充"字段外,其他个字段都是定长的。IP包头部的基本长度为20字节,如果加上最长40字节的“选项”字段,则,IP包头部最长为60字节.(20+40)
};
unsigned char serviceType; //”服务类型“,该字段长为8位,用来表示路由器如何处理该数据包;该8位分成三部分:
/*
最高的3位表示优先级,用来说明IP数据包的重要性,优先级越高越重要,则路由器优先对他处理;
有高位到底位:111表示网络控制,110表示网络间控制,101表示重要(CRITIC/ECP),100表示即时优先,011表示即时,010表示立刻,001表示优先,000表示普通
*/
/*
中间4位表示服务类型,从高位到低位:D(延时)、 T(吞吐量)、 R(可靠性)、 C (成本);
DTRC:1111表示安全的最高级,1000表示延时最小,0100表示吞吐量最大,0010表示可靠性最大,0001表示成本最小,0000表示普通服务。
*/
//最低1位是保留位
unsigned short totalLen; //”总长度“字段,占16位;定义以字节为单位的IP数据包总长度;由于总长度字段的长度为16位,因此,IP数据包的最大长度=2的16次方-1=65535字节;数据部分的长度=总长度-头部长度;
unsigned short identifier;//”标识符“字段,长度16位,用来表示IP数据包的归属;每批IP数据包都需要有一个标识符,目的主机用来判断IP数据包属于哪一个服务
union
{
unsigned short flags;//”标志位“字段,(使用最高的3位);
//用来表示IP包是否可以分片;
//保留位、DF位、MF位:
// 最高位保留位为0,
//DF=0时,表示分片 ,DF=1时,表示不能对数据包分片;
//MF=1时,表示接收的不是最后一个分片,MF=0时,表示接收的是最后一个分片
unsigned short fragOffset;//"片偏移"字段,(使用低13位);用来表示分片在整个IP数据包中的相对位置
//片偏移值是以“8字节”为单位来计算,因此,分片的长度应该是“8字节”的整数倍
};
unsigned char timeToLive;//"生存周期"字段,长度为8位;
//用来表示IP数据包在传输过程中的寿命,通常用经过最多的路由器跳步数来限制
//IP数据包的传输延时是不确定的,为了避免由于路由表出错而循环传输,可以通过设置生存周期来解决这个问题
unsigned char protocol;//”协议”字段,长度为8位,用来表示IP数据包的高层协议类型,如下,相应的值对应的协议:
//1--ICMP,2--IGMP,4--IP in IP,6--TCP,8--EGP,17--UDP,41--IPv6,46--RSVP,89--OSPF
unsigned short headChecksum;//“头部校验和”字段,长度为16位;
unsigned int sourceAddr; //源IP地址 ,发送IP包的源主机地址
unsigned int destinAddr; //目的IP地址,接收IP包的目的主机地址
//unsigned char options; //“选项”字段,长度为0~40个字节;
// 主要用于控制和测试这两个目的。在使用选项字段的过程中,有可能出现头部长度不为32位的整数倍的情况,这时就需要通过充位来凑齐
}ip_head;
//校验和计算
unsigned short checkSum(unsigned short *buffer,int size)
{
unsigned long cksum=0; //32位,不用16位,为了保留,16位相加时,最高位的进位
//先求和
while(size>1)
{
cksum+=*buffer++; //buffer是16位,每一次都是以16位长度加一次
size-=sizeof(unsigned short); //当size小于16位时,退出相加,下面else把不足16位的那部分单独处理
}
if(size)
{
cksum+=*(unsigned*)buffer;//把不足16位的那部分单独处理--先‘填充’满16位再加//无符号 短整型指针 强制转换为 无符号 字符型指针
}
//再把和取反,才得到想要的结果
cksum=(cksum>>16)+(cksum & 0xffff); //cksum的高16位+cksum的低16位//(32位的cksum的高16位移到低16位,而高16位被0填充)+(32位的cksum和16位的0xffff相与的结果);//32位的和16位的相与时,先将16位的扩展为32位,原先的16位做为扩展后的32位的低16位,高16位用0填充,实际意义就是,取cksum的低16位
cksum+=(cksum>>16); //说白了就是循环加;;把进位到高16位的1,加回到低16位,而且,首先把该高16位变为低16位,才能加
return (unsigned short)(~cksum); //~是二进制取反,最终所要的头部校验和
}
void main()
{
string intStr="E:\\infile.txt";
string outStr="E:\\outfile.txt";
fstream outFile;
outFile.open(outStr,ios::in|ios::out|ios::trunc);//ios::trunc将先前的文件内容移除ios::app 追加模式打开文件夹, 以ios::app打开,如果没有文件,那么生成空文件;如果有文件,那么在文件尾 追加
if(!outFile.is_open())
{
cout<<"无法打开文件!!"<>4 )<>5)<<" 服务类型(中间4位)--"<<((ip.serviceType>>1) & 0x0f)<>5)右移5位;((ip.serviceType>>1) & 0x0f),先右移1位,再相与运算,最后取得低4位
cout<<"总长度(=头部长度+数据部分长度)"<>15) & 0x01)<<" DF位(1表示不能对数据包分片,0表示可以分片)--"<<((ip.flags>>14) & 0x01)<<"MF位(1表示接收的不是最后一个分片,0表示接受的是最后一个分片)--"<<((ip.flags>>13) & 0x01)<
本文档为【IP分片重组--IP_fenPian_chongZu--失败了原因--是memcpy(check,&ip,20)不是memset(check,&ip,20);】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑,
图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。