如何解决接收部分在 TCP 套接字编程中工作不正常
我正在编写 TCP 套接字编程。
客户: 客户端将从服务器接收文件列表 --> 向服务器发送文件名 --> 从服务器接收文件
我的问题:
- 服务器正确发送文件列表。我打印出来了,所有的都很好地发送了。但是,即使服务器发送 while 循环已完成,客户端也能很好地接收它,但 while 循环并未完成。
[客户]
while ((read_cnt=read(sd,buf,BUF_SIZE)) != 0) {
read_cnt=read(sd,BUF_SIZE);
printf("%s\n",buf);
}
[服务器]
while ((entry=readdir(dir)) != NULL) {
sprintf(buf,"%s\n",entry->d_name);
write(clnt_sd,strlen(buf));
}
- 服务器发送 17 条消息,但客户端收到 15 条消息,while 循环未完成。当while循环收到“finish”时,使客户端完成while循环-->即使服务器发送了17条消息,它仍然收到15条消息。
[客户]
while (1) {
read_cnt=read(sd,BUF_SIZE);
fwrite((void*)buf,1,read_cnt,fp);
printf("%s\n",buf);
if (strstr(buf,"fin") != NULL) {
break;
}
total_read += read_cnt;
pcnt = ((total_read/ file_size) * 100.0)/10;
printf("(%.0d %%) Send %.0f / %.0f bytes.\n",pcnt*10,total_read,file_size);
}
[服务器]
FILE *fp;
fp = fopen(file_name,"r");
if (fp == NULL) {
printf("File not Exist");
exit(1);
}
fseek(fp,SEEK_END);
int file_size = ftell(fp);
sprintf(buf,"%d",file_size);
write(clnt_sd,read_cnt);
fseek(fp,SEEK_SET);
while (feof(fp) == 0) {
read_cnt = fread((void*)buf,BUF_SIZE,fp);
write(clnt_sd,read_cnt);
}
fclose(fp);
我尝试了 memset,bzero 来使缓冲区为空,但没有用。 我认为问题出在客户端部分,因为当我使用打印检查服务器端时,它们发送良好并完成了 while 循环。但是不知道客户端的接收过程有什么问题。请让我知道是什么问题。
解决方法
服务器发送17条消息,客户端收到15条消息
完全正常。
TCP 是流协议,而不是消息传递协议。您在一侧“发送”的内容可能不是另一端收到的确切字节数。您必须期望消息在 read/recv 调用之间和之内分块、合并或分段到达。您甚至不能假设您作为 4 字节消息发送的初始“大小”写入是在同一个 line = '.'.join(line.split('.')[::-1])
调用中作为完整消息接收的。
实现您的客户端代码以期望 find-numbers
和 @Column(name = "personalDetails",columnDefinition = "json")
@JsonRawValue
String personalDetails;
返回随机字节数,最多为您传入的缓冲区大小。如果您获得的字节数少于预期,您需要再次调用 read
以接收其余部分 - 根据需要调整目标缓冲区指针。或者使用带有 read
的 recv
标志(而不是读取)以在一次调用中获取所有数据。您仍然需要检查缓冲区的结果,以确保获得了预期的字节数、流没有关闭,并验证没有发生错误(-1 返回)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。