0

我目前正在尝试用 C 编写一个 tftp。但是我在读取我发送的数据包时遇到了一些困难。这是我所拥有的:我发送的结构:

typedef struct {
short type;
short block_num;
char* data;
} data_t;

发送数据包的功能(服务器端):

 if ( s = sendto (serverSocket, data, 512 ,0,
                    (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0 )
                {
                    perror("sendto");
                    exit(1);
                }

由于某种原因 s = 0,我不确定它是否正确。

客户端:

  char buffer[512 ];
  if ( (n = recv(serverSocket, buffer, 512-1,0)) < 0 )
        {
            perror("recv");
            exit(1);
        }
   data_t * data = malloc (1024);
   data->data = malloc(512);
   create_data(buffer,data)

和 create_data 函数:

int create_data( char * buffer, data_t* request)

{

data_t * tmp = (data_t*) buffer;
request->type = tmp->type;
request->block_num = tmp->block_num;
strcpy(request->data, tmp->data);
return 0;
}

不幸的是它不起作用,似乎问题来自 strcpy in create_data ,但我不知道为什么。

这是 serverSocket 创建的代码(服务器端)

memset( (char *) &serv_addr,0, sizeof(serv_addr) );
serv_addr.sin_family = PF_INET;
serv_addr.sin_addr.s_addr = htonl(INADDR_ANY);
serv_addr.sin_port = htons(SERV_PORT);

/*
* Ouvrir socket UDP
*/
if ((serverSocket = socket(PF_INET, SOCK_DGRAM, 0)) <0)
{
    perror ("erreur socket");
    exit (1);
}
ttl=1;
if (setsockopt(serverSocket, IPPROTO_IP, IP_TTL, &ttl, sizeof(ttl)) <0)
{
    perror ("setsockopt");
    exit (1);
}
if ( bind(serverSocket,(struct sockaddr *) & serv_addr, sizeof(serv_addr) ) < 0 )
{
    perror("servecho: erreur bind\n");
    exit(1);
}

request = malloc(sizeof(request_t));
                    ....
4

1 回答 1

1

sendto 返回已发送的字节数,因此如果返回 0,则表示未发送任何字节。

在代码的服务器部分,您似乎有一个以目的地为服务器地址的 sendto?(以 INETADDR_ANY 作为地址)。这可能是故障的原因。该过程应该是让服务器首先(在绑定之后)执行recvfrom,然后用sendto回复recvfrom中收到的相同地址。这是ServerClient的一个很好的例子。

接收到的数据或要发送的数据是二进制的,不能使用strcpy,strcpy会停在第一个空字节'\0',需要使用memcpy。

好的做法:在分配内存 data_t * data = malloc (1024);时,我建议你使用 malloc(sizeof(data_t));

于 2013-05-03T16:18:20.950 回答