0

再会。

作为一名学习低级 C 编程的计算机科学专业的学生,​​我被困在编写服务器-客户端通信程序的“经典”实践练习中。

目标是开发一个服务器组件,它接收来自远程客户端组件的命令,并将其作为本地 shell 命令执行;然后,命令的输出再次发送到客户端。很简单。

我的代码从客户端发送命令,服务器成功接收它,执行它并捕获输出。但是此时,当所说的服务器尝试将该输出回复给客户端时......出现问题并且客户端什么也没有收到。不知道问题是在服务器部分还是在客户端对应部分。

任何想法?提前致谢!

服务器:

struct sockaddr_in srvaddr, cliaddr;
memset(&srvaddr, 0, sizeof(srvaddr));
memset(&cliaddr, 0, sizeof(cliaddr));

int sk = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);

srvaddr.sin_family = AF_INET;
srvaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
srvaddr.sin_port = htons(42000);
bind(sk, (struct sockaddr*)&srvaddr, sizeof(srvaddr));
recvfrom(sk, recepcion, sizeof(recepcion), 0, (struct sockaddr*)&cliaddr, sizeof(cliaddr));

// [...] Portion of code with a Pipe pointing to a Fork which runs the command...

// And here is where, maybe, the communication is lost:
sendto(sk, recepcion, sizeof(recepcion), 0, (struct sockaddr*)&cliaddr, sizeof(cliaddr));

客户:

struct sockaddr_in srvaddr, cliaddr;

memset(&srvaddr, 0, sizeof(srvaddr));
memset(&cliaddr, 0, sizeof(cliaddr));

int sk = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);

cliaddr.sin_family = AF_INET;
cliaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
cliaddr.sin_port = htons(42001);

srvaddr.sin_family = AF_INET;
srvaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
srvaddr.sin_port = htons(42000);

// [...] Some other code catching the command from the argument paramenters:

sendto(sk, comando, strlen(comando), 0, (struct sockaddr*)&srvaddr, sizeof(srvaddr));

// And here's where the server reply should be, but theres nothing:
recvfrom(sk, buff, sizeof(buff), 0, (struct sockaddr*)&srvaddr, sizeof(srvaddr));

假设我使用以下命令打印所有痕迹: fprintf(stderr, ""); 因此,由于分叉而失去终端的焦点应该不是问题。

再见,谢谢!

4

1 回答 1

0

问题很可能是recvfrom电话。如果您查看手册页,您将看到源地址长度是一个指针。我不知道你是如何设法让它在没有错误或警告的情况下编译的。

您需要将大小初始化为socket-address结构的实际大小,传递一个指向它的指针,recvfrom函数将填充实际大小:

socklen_t cliaddrlen = sizeof(cliaddr);
recvfrom(sk, recepcion, sizeof(recepcion), 0,
         (struct sockaddr *) &cliaddr, &cliaddrlen);

哦,我假设您检查实际代码中的错误?

于 2014-02-11T19:27:53.207 回答