我在 Linux 平台上写了这段代码。
当这个程序运行时,它期望打印HTTP header
和html content
。
就像:
HTTP/1.1 200 OK\r\n
...
...
<!DOCTYPE html>
...
</html>
但是当我运行它的时候,我发现它只是打印HTTP header
这是我的 C 代码:
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <netdb.h> // for struct sockaddr_in AF_IN
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h> // for inet_pton
#include <netinet/in.h> // for IPPROTO_TCP
#define PORT "80"
#define BAIDU_IP "119.75.217.56"
#define GET_INFO "GET / HTTP/1.1\r\nHost: www.baidu.com:80\r\n\r\n"
int main()
{
int sock_local;
in_port_t port = atoi(PORT);
struct sockaddr_in server;
memset(&server, 0, sizeof(server));
server.sin_family = AF_INET;
server.sin_port = htons(port);
sock_local = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
assert(sock_local > 0);
int retVal = -1;
retVal = inet_pton(AF_INET, BAIDU_IP, &server.sin_addr.s_addr);
assert(retVal == 1);
if (connect(sock_local, (struct sockaddr*)&server, sizeof(server)) < 0)
{
perror("connect");
exit(EXIT_FAILURE);
}
ssize_t nByte = send(sock_local, GET_INFO, strlen(GET_INFO), 0);
if( nByte <= 0)
{
perror("send");
exit(EXIT_FAILURE);
}
char BUF[BUFSIZ];
size_t recived_len = 0;
while ((recived_len = recv(sock_local, BUF, BUFSIZ-1, 0)) > 0)
{
int statu;
BUF[recived_len] = '\0';
printf("%s", BUF);
statu = (recived_len==BUFSIZ-1) ? 0 : 1;
if (statu) break;
}
if (recived_len < 0)
{
perror("recv");
}
close(sock_local);
return 0;
}
你能帮忙接收 HTTP head
和 'html content' 吗?
我不知道为什么它不起作用。
======================解决方法======================== =====
我很高兴地说,我自己找到了解决这个问题的方法。
我删除了 if (statu) break;
,然后它按我预期的那样工作!
最佳答案
问题似乎就在这里:
statu = (recived_len==BUFSIZ-1) ? 0 : 1;
if (statu) break;
我不知道你为什么包含这段代码。除非您在上一次读取时完全填充缓冲区,否则它似乎会退出循环。你这样做的原因是什么?
删除这两行代码,它应该可以工作。
(哦,顺便说一下,这不是你拼写“received”的方式。)
关于c - 此 C 代码仅获取 HTTP header ,但不是 html 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10378213/