您好,我的套接字有问题。我正在尝试获取网页源,我得到了我需要的一切,但是在响应标题和页面源之间我得到了一些额外的符号,所以我的问题是为什么我得到那些额外的符号。
我从某个地方得到那个“18ad”......
来源来自页面:
<..>
Server: Apache-Cloud
Transfer-Encoding: chunked
Date: Thu, 27 Sep 2012 14:46:43 GMT
Connection: close
X-Cache: M
18ad
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xh
<..>
十六进制视图:
char: X-Cache: M......18ad...<!DO
hex : 58 2D 43 61 63 68 65 3A 20 4D 0D 0D 0A 0D 0D 0A 31 38 61 64 0D 0D 0A 3C 21 44 4F
请求头:
$GET / HTTP/1.1\r\n
Host: www.demotivation.us\r\n
Connection: close\r\n\r\n
我的代码:
char* ip = "www.demotivation.us";
char* url = "92.61.41.215";
<..>
sockAddr.sin_family = AF_INET;
sockAddr.sin_addr.s_addr = inet_addr(ip);
sockAddr.sin_port = htons(80);
<..>
s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
connect(s, (SOCKADDR*)&sockAddr, sizeof(SOCKADDR_IN);
<..>
// receive source to temporary buffer
do
{
bytes = recv(s, buffer, BUFFER_SIZE, 0);
buffer[bytes] = '\0';
cout << buffer;
} while(bytes > 0);