2012-08-15 105 views
0

我正在研究一个函数,它会(当它完成时)返回一个html页面的输出。我刚刚从StackOverFlow获得帮助,了解recv的工作方式,现在我正在完成该功能。我现在遇到的问题是,看起来插座没有正确打开。该recv函数只是返回-1(表示一个套接字错误,我相信)套接字不打开?

下面是代码:

#include <stdio.h> 
#include <stdlib.h> 
#include <winsock2.h> 
#include <windows.h> 
#define BUFFERSIZE 4096 

char *readsite(const char *url, const char *ip, const int port) 
{ 
    char *req, *ret, *tmp, tmpbuff[256]; 
    int c, i, q; 
    SOCKET sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); 
    struct sockaddr_in sa = { 0 }; 
    sa.sin_port = htons(port); 
    sa.sin_addr.s_addr = inet_addr(ip); 

    for(i = 0; url[i] != 0x00; i++); 
    req = malloc((i + 18) * sizeof(char)); 
    if(!req) return NULL; 
    req[0] = 'G'; 
    req[1] = 'E'; 
    req[2] = 'T'; 
    req[3] = ' '; 
    for(c = 4, q = 0; q <= i; c++, q++) req[c] = url[q]; 
    req[c - 1] = ' '; 
    req[c + 0] = 'H'; 
    req[c + 1] = 'T'; 
    req[c + 2] = 'T'; 
    req[c + 3] = 'P'; 
    req[c + 4] = '/'; 
    req[c + 5] = '1'; 
    req[c + 6] = '.'; 
    req[c + 7] = '0'; 
    req[c + 8] = '\r'; 
    req[c + 9] = '\n'; 
    req[c + 10] = '\r'; 
    req[c + 11] = '\n'; 
    req[c + 12] = '\0'; 
    connect(sock, (struct sockaddr*)&sa, sizeof(sa)); 
    for(i = 0; req[i] != 0x00; i++); 
    send(sock, req, i, 0); 
    printf("%s %s", req, ip); 
    free(req); 
    ret = malloc(BUFFERSIZE); 
    if(!ret) return NULL; 
    c = 0;    // recv value 
    i = BUFFERSIZE; // buffer size 
    q = 0;    // loaded bytes 
    while((c = recv(sock, tmpbuff, sizeof(tmpbuff), 0)) > 0) 
    { 
     if((q + c + 1) > i) 
     { 
       i += BUFFERSIZE; 
       if(!(tmp = realloc(ret, i))) return NULL; 
       ret = tmp; 
     } 
    } 
} 

int main(void) 
{ 
     readsite("http://www.google.com/", "74.125.226.226", 80); 
    return 0; 
} 
+4

你知道的一样的strlen()函数中, strcpy(),strcat()?此外,请检查所有系统调用返回(例如来自连接),如果调用失败,请使用getLastError()API调用(或者如果您是企鹅,请使用errno)来查找出错的地方。 – 2012-08-15 16:35:57

+0

啊谢谢你看起来像一个WSA初创公司没有成功执行,很酷的小功能!再次感谢! – 2012-08-15 16:46:49

回答

0

使用错误的错误代码,找出了问题; !PERROR()是一个伟大的功能,对于这一点,把它的错误代码的检查后= 0这里是如此的在你的代码做的建议方法:

while(1) 
{ 
    if ((c = recv(sock, tmpbuff, sizeof(tmpbuff), 0)) < 0) { 
     perror("Receive error"); 
    } 
    else if (c == 0) { 
     break; 
    } 
    if((q + c + 1) > i) 
    { 
      i += BUFFERSIZE; 
      if(!(tmp = realloc(ret, i))) return NULL; 
      ret = tmp; 
    } 
} 
+0

也谢谢!这真的很酷! – 2012-08-15 17:04:03

相关问题