Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
16 / 16 / 1
Регистрация: 09.03.2013
Сообщений: 65
#1

Winsock. Recv с ошибкой 10053(WSAECONNABORTED) - C++

10.09.2013, 17:45. Просмотров 1027. Ответов 9
Метки нет (Все метки)

Приветствую.
Сначала отсылаю запрос на сервер, получаю ответ, обрабатываю.
Всё хорошо, но вот после отправки второго запроса, получение ответа завершается с ошибкой 10053(WSAECONNABORTED).
Извиняюсь за неразборчивый код, только учусь.
Основа кода взял с msdn.
Весь код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
#define WIN32_LEAN_AND_MEAN
 
#include <windows.h>
#include <winsock2.h>
#include <ws2tcpip.h>
#include <stdlib.h>
#include <stdio.h>
 
 
// Need to link with Ws2_32.lib, Mswsock.lib, and Advapi32.lib
#pragma comment (lib, "Ws2_32.lib")
#pragma comment (lib, "Mswsock.lib")
#pragma comment (lib, "AdvApi32.lib")
 
 
#define DEFAULT_BUFLEN 512
#define DEFAULT_PORT "80"
 
int Send(SOCKET ConnectSocket, const char* sendbuf, char *recvbuf,  int recvbuflen);
void ParseTag(char *buf, const char *input, char *tag);
 
int __cdecl main(int argc, char **argv) 
{
    WSADATA wsaData;
    SOCKET ConnectSocket = INVALID_SOCKET;
    struct addrinfo *result = NULL,
                    *ptr = NULL,
                    hints;
    char servname[] = "109.234.156.250";
    char recvbuf[DEFAULT_BUFLEN];
    int iResult;
    int recvbuflen = DEFAULT_BUFLEN;
 
    // Инициализация Winsock
    iResult = WSAStartup(MAKEWORD(2,2), &wsaData);
    if (iResult != 0) {
        printf("WSAStartup failed with error: %d\n", iResult);
        return 1;
    }
 
    ZeroMemory( &hints, sizeof(hints) );
    hints.ai_family = AF_UNSPEC;
    hints.ai_socktype = SOCK_STREAM;
    hints.ai_protocol = IPPROTO_TCP;
 
    // Resolve the server address and port
    iResult = getaddrinfo(servname, DEFAULT_PORT, &hints, &result);
    if ( iResult != 0 ) {
        printf("getaddrinfo failed with error: %d\n", iResult);
        WSACleanup();
        return 1;
    }
 
    // Attempt to connect to an address until one succeeds
    for(ptr=result; ptr != NULL ;ptr=ptr->ai_next) {
 
        // Create a SOCKET for connecting to server
        ConnectSocket = socket(ptr->ai_family, ptr->ai_socktype, 
            ptr->ai_protocol);
        if (ConnectSocket == INVALID_SOCKET) {
            printf("socket failed with error: %ld\n", WSAGetLastError());
            WSACleanup();
            return 1;
        }
 
        // Connect to server.
        iResult = connect( ConnectSocket, ptr->ai_addr, (int)ptr->ai_addrlen);
        if (iResult == SOCKET_ERROR) {
            closesocket(ConnectSocket);
            ConnectSocket = INVALID_SOCKET;
            continue;
        }
        break;
    }
 
    freeaddrinfo(result);
 
    if (ConnectSocket == INVALID_SOCKET) {
        printf("Unable to connect to server!\n");
        WSACleanup();
        return 1;
    }
    char sendbuf[1024];//&getidea=5
    char params[256] = "key=fff&user=0&method=office&sig=8b4e54762b191639e355a80592b2f4bb";
    sprintf(sendbuf,    "POST /prison/universal.php HTTP/1.1\r\n"
                        "Host: %s\r\n"
                        "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:18.0) Gecko/20100101 Firefox/18.0\r\n"
                        "Connection: keep-alive\r\n"
                        "Content-Type: application/x-www-form-urlencoded\r\n"
                        "Content-Length: %i\r\n"
                        "\r\n%s",
                        servname, strlen(params), params);
    Send(ConnectSocket, sendbuf, recvbuf, recvbuflen);
 
    char ideas[2];
    ParseTag(ideas, recvbuf, "ideascount");
    
    sprintf(params, "key=fff&user=0&method=office&sig=8b4e54762b191639e355a80592b2f4bb&getidea=%s", ideas);
    sprintf(sendbuf,    "POST /prison/universal.php HTTP/1.1\r\n"
                        "Host: %s\r\n"
                        "User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:18.0) Gecko/20100101 Firefox/18.0\r\n"
                        "Connection: keep-alive\r\n"
                        "Content-Type: application/x-www-form-urlencoded\r\n"
                        "Content-Length: %i\r\n"
                        "\r\n%s",
                        servname, strlen(params), params);
    Send(ConnectSocket, sendbuf, recvbuf, recvbuflen);
    // shutdown the connection since no more data will be sent
    iResult = shutdown(ConnectSocket, SD_SEND);
    if (iResult == SOCKET_ERROR) {
        printf("shutdown failed with error: %d\n", WSAGetLastError());
        closesocket(ConnectSocket);
        WSACleanup();
        return 1;
    }
    
    // cleanup
    closesocket(ConnectSocket);
    WSACleanup();
 
    system("pause");
    return 0;
}
int Send(SOCKET ConnectSocket, const char* sendbuf, char *recvbuf,  int recvbuflen)
{
    int iResult;
    // Send an initial buffer
    iResult = send( ConnectSocket, sendbuf, (int)strlen(sendbuf), 0 );
    if (iResult == SOCKET_ERROR) {
        printf("send failed with error: %d\n", WSAGetLastError());
        closesocket(ConnectSocket);
        WSACleanup();
        return 1;
    }
 
    printf("Bytes Sent: %ld\n", iResult);
 
    // Receive until the peer closes the connection
    char buf[2048] = {0};
    do {
        iResult = recv(ConnectSocket, recvbuf, recvbuflen, 0);
        if ( iResult > 0 ) {
            printf("Bytes received: %d\n", iResult);
            recvbuf[iResult] = '\0';
            strcat(buf, recvbuf);
 
        } else if ( iResult == 0 ) {
            printf("Connection closed\n");
            printf(buf);
        } else {
            printf("recv failed with error: %d\n", WSAGetLastError());
        }
 
        
    } while( iResult > 0 );
    recvbuf = buf;
}
void ParseTag(char *buf, const char *input, char *tag)
{
  const char *start, *end;
  char openTag[64], closeTag[64];
  sprintf_s(openTag, "<%s>", tag);
  sprintf_s(closeTag, "</%s>", tag);
  if((start = strstr(input, openTag)) != NULL)
  {
    start += strlen(openTag);
    if((end = strstr(start, closeTag)) != NULL)
    {
      if(buf != NULL)
      {
        memcpy(buf, start, (end - start));
        buf[end - start] = '\0';
      }
    }
  }
  else
  {
      buf[0] = '\0';
  }
}
Миниатюры
Winsock. Recv с ошибкой 10053(WSAECONNABORTED)  
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Raali
622 / 326 / 34
Регистрация: 06.07.2013
Сообщений: 1,054
Завершенные тесты: 1
10.09.2013, 17:51     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #2
7 строка в консоли разве не указывает на то что соединение разорвано?
eXtream
24 / 24 / 0
Регистрация: 10.03.2010
Сообщений: 161
10.09.2013, 17:54     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #3
Расшифровка ошибки [10053]: Программа на вашем хост-компьютере разорвала установленное подключение. Ну а уж почему пробуйте трасировать и анализировать отсылаемые и принимаемые данные, может быть где-то buffer overflow
Raali
622 / 326 / 34
Регистрация: 06.07.2013
Сообщений: 1,054
Завершенные тесты: 1
10.09.2013, 17:57     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #4
Цитата Сообщение от eXtream Посмотреть сообщение
Ну а уж почему пробуйте трасировать и анализировать отсылаемые и принимаемые данные, может быть где-то buffer overflow
вобщем дебажте, ставьте брейкпойнты перед Send , в самой Send и после
16 / 16 / 1
Регистрация: 09.03.2013
Сообщений: 65
10.09.2013, 18:03  [ТС]     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #5
Raali, Получается, что после отправки, получения нужно заново делать подключение? А нельзя как нибудь обмениваться данными с сервером не разрывая подключения.
При первом вызове recv получаю заголовок, второй - ?, 3 - "тело", 4 - ?, 5 - ?
Вроде переполнения нет, просто recv закрывает подключение т.к нет данных для получения.
Raali
622 / 326 / 34
Регистрация: 06.07.2013
Сообщений: 1,054
Завершенные тесты: 1
10.09.2013, 18:06     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #6
Цитата Сообщение от Посмотреть сообщение
нужно заново делать подключение?
вообще не нужно обычно, а может сервер такой который сразу разрывает после 1 сообщения?
16 / 16 / 1
Регистрация: 09.03.2013
Сообщений: 65
10.09.2013, 18:14  [ТС]     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #7
Нет, вроде не сервер. В коде косяк.
Raali
622 / 326 / 34
Регистрация: 06.07.2013
Сообщений: 1,054
Завершенные тесты: 1
10.09.2013, 18:18     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #8
попробуйте проверить второе сообщение на валидность тогда
16 / 16 / 1
Регистрация: 09.03.2013
Сообщений: 65
10.09.2013, 18:25  [ТС]     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #9
На валидность чего? Данные для отправки правильны(не в них дело), отправляются нормально, а при получении сразу ошибка.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.09.2013, 14:08     Winsock. Recv с ошибкой 10053(WSAECONNABORTED)
Еще ссылки по теме:

C++ Узнать, всё ли прочитал recv или нет
Winsock - UDP вместо ТСР C++
C++ Winsock.h ругается на ssleay32.dll
C++ MPI зависает на Recv
WSA recv не читает все сообщение C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
16 / 16 / 1
Регистрация: 09.03.2013
Сообщений: 65
12.09.2013, 14:08  [ТС]     Winsock. Recv с ошибкой 10053(WSAECONNABORTED) #10
Скорее всего дело в сервере. Отправляю ему в заголовках "Connection: keep-alive"(не закрывать сокет), а он мне "Connection: close"(закрыл).
Пробовал отправить другим серверам. Отвечают нормально "Connection: keep-alive"
Наверное после каждого запроса придётся подключаться заново.
Yandex
Объявления
12.09.2013, 14:08     Winsock. Recv с ошибкой 10053(WSAECONNABORTED)
Ответ Создать тему
Опции темы

Текущее время: 20:18. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru