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

------解决方案--------------------
要让发送完马上断开,要在HTTP头指明:
strcat(sendbuf, "Connection: close\r\n");
另外你接受缓冲print有问题,收到的内容没有\0终止符的,建议改成这样
定义
补个终止符
------解决方案--------------------
不知道有多少前人掉在TCP Socket
send(人多)send(病少)send(财富)
recv(人多病)recv(少财富)
陷阱里面啊!
http://topic.****.net/u/20120210/09/51109ed0-07b9-41f2-b487-a51597f2ca01.html
------解决方案--------------------
------解决方案--------------------
用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;
}
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;
}
}