解决网络数据粘包的问题

原创 2006年05月25日 12:27:00

一个网络上来的数据包之后,我们必需将收到的数据包整理成为一个一个的完成的数据包.这里写了一个代码来搞定这个问题的.
首先我们需要有一个内存缓冲区.还有我们已经使用了这个缓冲区的大小的标志.


void getData(const char* buff,int nSize)
{
 char *pCheckBuff=(char*)buff; // 检查的缓冲区
 int nCountSize=nSize; // 缓冲区的大小
 bool bBuff=false; // 是否使用本地缓冲区

 // 如果以前有断的数据包
 if (nUsedSize_!=0)
 {
  memcpy(buf_+nUsedSize_,buff,nSize);
  nUsedSize_+=nSize;
  bBuff=true;
  nCountSize=nUsedSize_;
 }

 // 开始对 pCheckBuff 内存块进行解包
 // 当处理完成,或是数据包的长度没有这么长的时候退出
 int offset=0;
 int leave=nCountSize;
 while (1)
 {
  leave=nCountSize-offset;
  // 得到数据包头
  if (leave>DATA_HEAD_SIZE)
  {
   DataHead* pHead=(DataHead*)pCheckBuff+offset;
   // 检查数据包是否正确
   if (check_head(pHead))
   {
    // 检查数据体是否完整
    if (pHead->nSize<=leave)
    {
     ACE_Message_Block *new_mb = blockTash_.get_free_block();
     new_mb->copy(pCheckBuff+offset,pHead->nSize);
     //new_mb->wr_ptr(pHead->nSize);
     ((Acceptor*)pAcceptor_)->on_user_data(this->nIndex_,*new_mb,pHead->nSize);
     //
     // ((Acceptor*)pAcceptor_)->on_user_data(this->nIndex_,mb,result.bytes_transferred ());
     offset+=pHead->nSize;
    }
    // 不完整的数据包
    else
    {
     goto lable1;
    }
   }
   // 错误的数据包.将把这一次的数据全部丢失
   else
   {
    nUsedSize_=0;
    leave=0;
    break;
   }
  }
  // 没有完整的数据包头
  else
  {
   goto lable1;
  }
 }
 return ;

 // 保存数据
 // 移动缓冲区的数据
lable1:

 // 在本地的缓冲区中
 if (leave!=0)
 {
  memcpy(buf_,pCheckBuff+offset,leave);
  nUsedSize_=leave;
 }
 return ;
}

解决TCP网络传输粘包问题

  • 2012年11月07日 17:11
  • 56KB
  • 下载

【转】 解决TCP网络传输“粘包”问题

解决TCP网络传输“粘包”问题 作者:杨小平 王胜开                 当前在网络传输应用中,广泛采用的是TCP/IP通信协议及其标准的socket应用开发编程接口(API)。T...
  • wateryh
  • wateryh
  • 2011年08月25日 10:26
  • 251

解决TCP网络传输“粘包”问题

当前在网络传输应用中,广泛采用的是TCP/IP通信协议及其标准的socket应用开发编程接口(API)。TCP/IP传输层有两个并列的协议:TCP和UDP。其中TCP(transport contro...
  • htt9931
  • htt9931
  • 2013年08月04日 17:22
  • 1478

解决TCP网络传输“粘包”问题(经典)

转载链接:http://blog.csdn.net/zhangxinrun/article/details/6721508 当前在网络传输应用中,广泛采用的是TCP/IP通信协议及其标准的socke...
  • yhhwatl
  • yhhwatl
  • 2016年12月22日 09:26
  • 266

怎么解决TCP网络传输“粘包”问题

当前在网络传输应用中,广泛采用的是TCP/IP通信协议及其标准的socket应用开发编程接口(API)。TCP/IP传输层有两个并列的协议:TCP和UDP。其中TCP(transport contro...
  • XSL1990
  • XSL1990
  • 2013年11月19日 03:01
  • 933

linux网络编程之socket(五):tcp流协议产生的粘包问题和解决方案

linux网络编程之socket(五):tcp流协议产生的粘包问题和解决方案 标签: 网络编程linux 2013-12-16 10:58 475人阅读 评论(0) 收藏 举报 ...

TCP网络传输“粘包”问题,经典解决(附代码)

关于TCP网络传输粘包,网上很多人写了原理。总结起来就一句话(这里拿Server和Client长连接,Server和Client之间通过信令传输做说明) Server发送的时候按照一条条信令发送,到达...
  • hherima
  • hherima
  • 2015年01月20日 17:41
  • 3352

linux网络编程之socket(五):tcp流协议产生的粘包问题和解决方案

我们在前面曾经说过,发送端可以是一K一K地发送数据,而接收端的应用程序可以两K两K地提走数据,当然也有可能一次提走3K或6K数据,或者一次只提走几个字节的数据,也就是说,应用程序所看到的数据是一个整体...

UNIX网络编程——tcp流协议产生的粘包问题和解决方案

我们在前面曾经说过,发送端可以是一K一K地发送数据,而接收端的应用程序可以两K两K地提走数据,当然也有可能一次提走3K或6K数据,或者一次只提走几个字节的数据,也就是说,应用程序所看到的数据是一个整体...

解决TCP网络传输“粘包”问题

在应用开发过程中,基于TCP网络传输的应用程序有时会出现粘包现象(即发送方发送的若干包数据到接收方接收时粘成一包)。针对这种情况,笔者进行了专题研究与实验。本文重点分析了TCP网络粘包问题,并结合实验...
  • kyfvc
  • kyfvc
  • 2012年09月16日 11:10
  • 765
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:解决网络数据粘包的问题
举报原因:
原因补充:

(最多只允许输入30个字)