TCP粘包

一句话总结:通过自定义协议判断每个包的大小来避免粘包。

先看个简单的:

服务端:

#include <iostream>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <stdio.h>

using namespace std;
int main()
{
	struct sockaddr_in serAddr;
	int listenSock, cnntSock;
	listenSock = socket(AF_INET, SOCK_STREAM, 0);
	serAddr.sin_family = AF_INET;
	serAddr.sin_addr.s_addr = INADDR_ANY;
	serAddr.sin_port = htons(1248);

	bind(listenSock, (const struct sockaddr *)&serAddr, sizeof(sockaddr_in));
	listen(listenSock, 10);

	struct sockaddr_in cliAddr;
	socklen_t len = sizeof(sockaddr_in);
	cnntSock = accept(listenSock, (struct sockaddr*)&cliAddr, &len);
	cout<< "IP:" <<inet_ntoa(cliAddr.sin_addr) <<", port:"<<cliAddr.sin_port<<endl;
	unsigned int total = 0;
	while(1)
	{
		getchar();
		cout <<"read msg..."<<endl;
		char buf[6000] = {0};
		int ret = recv(cnntSock, buf, sizeof(buf), 0);
		total += ret;
		cout << "msg:" <<endl;
		cout << buf;
		cout << "recv msg size:" << ret << "total size:" << total <<endl;
		break;
	}
	close(cnntSock);
	close(listenSock);
	return 0;
}

直接用nc模拟



然后用真正客户端试下

#include <iostream>
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
using namespace std;

int main()  
{  
    int sockClient = socket(AF_INET, SOCK_STREAM, 0);  
    struct sockaddr_in addrSrv;  
    addrSrv.sin_addr.s_addr = inet_addr("127.0.0.1");  
    addrSrv.sin_family = AF_INET;  
    addrSrv.sin_port = htons(1248);  
    connect(sockClient, ( const struct sockaddr *)&addrSrv, sizeof(struct sockaddr_in));  
     
    char buf[10] = {0};  
    for(unsigned int i = 0; i < 10; i++) 
    {  
        buf[i] = 'd';   
    }  
      
    int ret = send(sockClient, buf, sizeof(buf) , 0);   
    cout << "buf size:" << sizeof(buf) << "ret:" << ret <<endl; 
    for(unsigned int i = 0; i < 10; i++) 
    {  
        buf[i] = 'p';   
    } 

    ret = send(sockClient, buf, sizeof(buf) , 0);   
    cout << "buf size:" << sizeof(buf) << "ret:" << ret <<endl; 

    getchar();  
    close(sockClient);  
  
    return 0;  
}  


从下图运行结果可以看出,发包发了两个,由于客户端没有及时接收,最后两个包一起接收了。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值