2012-08-15 97 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

相關問題