服务器无法在c winsock编程中接收客户端消息

时间:2015-09-03 05:14:54

标签: c sockets winsock winsock2

你好朋友我是c的套接字编程的新手。我在网上阅读了一些教程并开始工作。下面的程序是我的套接字客户端和使用WINDOWS中的winsock2库的服务器程序。

每当我运行程序时,在服务器接受客户端连接之前都没有错误。但是在客户端发送消息之后服务器无法接收消息。 WSAGetLastError()函数返回错误代码为10038.I尝试更改端口,增加和减少邮件大小。 帮帮我朋友。

服务器代码

#include<stdio.h>
#include<conio.h>
#include<WinSock2.h>
#pragma comment(lib,"ws2_32.lib")
int _tmain(int argc, _TCHAR* argv[])
{
WSADATA wsa;
int r;
char buf[4];
WSAStartup(MAKEWORD(2,2),&wsa);

SOCKET s= socket(AF_INET,SOCK_STREAM,0);

if ( s==INVALID_SOCKET)
{
    printf("\n failed to create socket error code : %d ",WSAGetLastError());
    WSACleanup();
    return 1;
}

sockaddr_in sin,cl;
sin.sin_family=AF_INET;
sin.sin_port=htons(80);
sin.sin_addr.s_addr=INADDR_ANY;

if(bind (s,(sockaddr *)&sin,sizeof(sin))==SOCKET_ERROR)
{
    printf("\nSocket not Bound\n");
    WSACleanup(); 
    return 1;
}

r=listen(s,2);
if(r==SOCKET_ERROR)
{
    printf("\nListening Failed\n");
    WSACleanup();
    return 1;
}
printf("\n Listening\n");

SOCKET client;
r= sizeof(sockaddr_in);
printf("\n Ready to accept");
while (client=accept(s,(sockaddr *)&cl,&r)!= INVALID_SOCKET)
{
printf("\nNew client found\n\n");
if(client == SOCKET_ERROR)
{
    printf("\nError connecting client error code : %d ",WSAGetLastError());
    WSACleanup();
    return 1;
}

r=recv(client,buf,4,0);
if(r==SOCKET_ERROR)
{
    printf("\nSocket not connected error code : %d",WSAGetLastError());
    WSACleanup();
    return 1;
}

printf("%s\n",buf);
}
getchar();
return 0;
}

客户端代码

#include <stdio.h>
#include <conio.h>
#include <WinSock2.h>
#pragma comment(lib,"ws2_32.lib")

int _tmain(int argc, _TCHAR* argv[])
{

WSADATA wsa;
WSAStartup(MAKEWORD(2,2),&wsa);
int r;
char *buf="data";

SOCKET t=socket(AF_INET,SOCK_STREAM,0);
if(t==SOCKET_ERROR)
{
    printf("\nFailed socket error code : %d ",WSAGetLastError());
    WSACleanup();
    return 1;
}

sockaddr_in server;
server.sin_family=AF_INET;
server.sin_addr.s_addr=inet_addr("192.168.0.142");
server.sin_port=htons(80);

printf("\nConnecting\n");
r=connect(t,(sockaddr *)&server,sizeof(server));
if(r==SOCKET_ERROR)
{
    printf("\nFailed to connect error code : %d ",WSAGetLastError());
    WSACleanup();
    return 1;
}
printf("\n connected\n");

 printf("\nSending data\n");
 r=send(t,buf,strlen(buf),0);
 if (r==SOCKET_ERROR)
 {
     printf("\nFailed to connect error code : %d ",WSAGetLastError());
     WSACleanup();
     return 1;
 }
 printf("\n Data sent\n");
return 0;
}

1 个答案:

答案 0 :(得分:0)

首先我们查看10038的含义。

SAENOTSOCK
10038 (0x2736)
An operation was attempted on something that is not a socket.

好的,所以你认为你有一个插座,但你真的不在你的一个电话中。关于哪个WSAGetLastError()函数返回10038,您并不是非常具体,但我会在此之后猜测该调用:

while (client=accept(s,(sockaddr *)&cl,&r)!= INVALID_SOCKET)

在C中,首先处理!=,然后处理分配。因此,您最终将accept返回的套接字与INVALID_SOCKET进行比较,然后将该布尔值分配给client。您希望分配然后比较套接字,因此您应该在赋值周围使用括号:

while ((client = accept(s,(sockaddr *)&cl,&r)) != INVALID_SOCKET)

另外,socket()会返回INVALID_SOCKET而不是SOCKET_ERROR,但会让两个人感到困惑,因此会导致问题。

此外,如果要打印它,则需要在接收方端空字符串终止字符串。

char buf[5];  /* 4 characters + 1 null-terminator */
...
buf[sizeof(buf) - 1] = '\0';    /* enforce that the buffer is always null terminated regardless of what the sender sends. */