2
我們有練習以面向對象的風格編寫web服務器。 所以我們爲WinSockets創建了一個類。我們希望循環主要部分(從接受到發送)以逐個處理連接(僅用於啓動;稍後將實施多線程)。OOP套接字不等待接受()
問題:第一次,建立連接一切正常,但服務器不會等待下一個連接接受。它說,它有一個連接,但是該描述符會引發一個錯誤,並顯示errornr「No Error」。
主:
NetInterface *socket;
#ifdef __unix__
socket = new UnixSocket();
#elif __WIN32__ || _MSC_VER
socket = new WinSocket();
#else
printf("Ihr System wird nicht Unterstützt");
#endif
socket->socketInit(PORT);
printf("server: waiting for connections...\n");
while(1) { // main accept() loop
char *their_addr = socket->akzeptieren();
if(their_addr == NULL) {
continue;
}
printf("server: got connection from %s\n", s);
socket->empfangen();
cout << socket->getInPacket() << endl;
}
WINSOCKET
class WinSocket : virtual public NetInterface
{
private:
WSADATA wsaData;
int iResult;
SOCKET sockfd;
SOCKET new_fd;
struct addrinfo *servinfo;
struct addrinfo hints;
struct addrinfo *p;
int iSendResult;
string incoming;
int recvbuflen;
char s[INET6_ADDRSTRLEN];
struct sockaddr_storage their_addr; // connector's address information
socklen_t sin_size;
int rv;
public:
WinSocket();
int socketInit(const char *port);
char *akzeptieren();
void empfangen();
void senden(string s);
string getInPacket();
void *get_in_addr(struct sockaddr *sa);
};
[....]
char *WinSocket::akzeptieren(){
sin_size = sizeof(their_addr);
new_fd = accept(sockfd, (struct sockaddr *)&their_addr, &sin_size);
if (new_fd == INVALID_SOCKET) {
perror("accept");
return NULL;
}
inet_ntop(their_addr.ss_family, get_in_addr((struct sockaddr *)&their_addr), s, sizeof s);
return s;
}