recv 数据不完整

场景:用C模拟了一个http请求,但是recv函数接收的数据不完整且欠安顺序获取信息

用C模拟了一个http请求,但是recv函数接收的数据不完整且不安顺序获取信息
用C模拟了一个http请求,但是recv函数接收的数据不完整且不安顺序获取信息
我把代码贴上
#include <stdio.h>
#include "winsock2.h"
//#pragma comment(lib, "ws2_32.lib") //2.0版本
int main() {
// Initialize Winsock.
WSADATA wsaData;
int iResult = WSAStartup( MAKEWORD(2,2), &wsaData );
if ( iResult != NO_ERROR ){
printf("Error at WSAStartup()\n");
}

// Create a socket.
SOCKET m_socket;
m_socket = socket( AF_INET, SOCK_STREAM, IPPROTO_TCP );
if ( m_socket == INVALID_SOCKET ) {
printf( "Error at socket(): %ld\n", WSAGetLastError() );
WSACleanup();
return 1;
}
// Connect to a server.
struct sockaddr_in clientService;
clientService.sin_family = AF_INET;
clientService.sin_addr.s_addr = inet_addr("113.106.90.157");
clientService.sin_port = htons( 80 );
if ( connect( m_socket, (SOCKADDR*) &clientService, sizeof(SOCKADDR)) == SOCKET_ERROR){
printf( "Failed to connect.\n" );
WSACleanup();
return;
}

// Send and receive data.
int bytesSent;

char sendbuf[1024];
sprintf(sendbuf,"%s","GET / HTTP/1.1\r\n");
strcat(sendbuf,"Host: www.chachaoo.com\r\n");
strcat(sendbuf,"Content-Encoding: utf-8\r\n");
strcat(sendbuf,"User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:25.0) Gecko/20100101 Firefox/25.0\r\n\r\n");

int bytesRecv = strlen(sendbuf);
char recvbuf[1024];
char *precvbuf = recvbuf;
bytesSent = send( m_socket, sendbuf, strlen(sendbuf), 0 );
printf( "Bytes Sent: %ld\n", bytesSent );

// bytesRecv = recv( m_socket, recvbuf, 2 , 0 );
// printf("\n %d\n",bytesRecv);


while( 1 ) {
    bytesRecv = recv(m_socket, recvbuf,1024 , 0);
    printf("%s",recvbuf);
 
   // printf("\n%d\n",bytesRecv);
    if(bytesRecv<=0){
     break;
    }  
   
}

 
 
close(m_socket);
return 0;


recv 数据不完整
recv 数据不完整
winsocket

------解决方案--------------------
要让发送完马上断开,要在HTTP头指明:
strcat(sendbuf, "Connection: close\r\n");
另外你接受缓冲print有问题,收到的内容没有\0终止符的,建议改成这样
定义
char recvbuf[1025];

补个终止符
	while( 1 ) {
    bytesRecv = recv(m_socket, recvbuf,1024 , 0);
        if (bytesRecv <= 0) break;
        recvbuf[bytesRecv+1] = 0;
    printf("%s",recvbuf);
}

------解决方案--------------------
不知道有多少前人掉在TCP Socket
send(人多)send(病少)send(财富)
recv(人多病)recv(少财富)
陷阱里面啊!
http://topic.****.net/u/20120210/09/51109ed0-07b9-41f2-b487-a51597f2ca01.html

------解决方案--------------------
void HexDump(char *buf,int len) {
    int i,j,k;
    char binstr[80];

    for (i=0;i<len;i++) {
        if (0==(i%16)) {
            sprintf(binstr,"%04x -",i);
            sprintf(binstr,"%s %02x",binstr,(unsigned char)buf[i]);
        } else if (15==(i%16)) {
            sprintf(binstr,"%s %02x",binstr,(unsigned char)buf[i]);
            sprintf(binstr,"%s  ",binstr);
            for (j=i-15;j<=i;j++) {
                sprintf(binstr,"%s%c",binstr,('!'<buf[j]&&buf[j]<='~')?buf[j]:'.');
            }
            printf("%s\n",binstr);
        } else {
            sprintf(binstr,"%s %02x",binstr,(unsigned char)buf[i]);
        }
    }
    if (0!=(i%16)) {
        k=16-(i%16);
        for (j=0;j<k;j++) {
            sprintf(binstr,"%s   ",binstr);
        }
        sprintf(binstr,"%s  ",binstr);
        k=16-k;
        for (j=i-k;j<i;j++) {
            sprintf(binstr,"%s%c",binstr,('!'<buf[j]&&buf[j]<='~')?buf[j]:'.');
        }
        printf("%s\n",binstr);
    }
}

------解决方案--------------------

while( 1 ) {
        memset(recvbuf, 0x00, sizeof(char)*1024);//加上这一行 你的输出就没有乱码的小尾巴了

        bytesRecv = recv(m_socket, recvbuf,1024 , 0);
        printf("%s",recvbuf);
      
       // printf("\n%d\n",bytesRecv);
        if(bytesRecv<=0){
            break;
        }     
        
    }