我试图一次发送一个4字节的文件,如果文件内容的长度不能被4整除,我会添加一些额外的空间而我发送它
当我发送一些字符串时它正在工作但是对于某些字符串recv()进入无限循环
Client.cpp
#include <iostream>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/types.h>
using namespace std;
int main(){
int ssock , csock ;
struct sockaddr_in server ;
server.sin_family = AF_INET ;
server.sin_port = htons(8088);
server.sin_addr.s_addr = inet_addr("127.0.0.1");
ssock = socket (AF_INET,SOCK_STREAM,0);
if (ssock == -1 ) {
cout << " Error " ; return 0 ;
}
connect(ssock , (sockaddr *)&server ,sizeof(server));
/*void *buff ;
int len = recv(ssock , buff ,1024,0 );
int *ptr = (int *)buff ;
cout << *ptr ;*/
void * buff ;
int len;
while(len = recv(ssock , buff ,4,0 )){
cout<<(char *)buff<<len<<"\n";
}
return 0 ;
}
server.cpp
#include <iostream>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <fstream>
#include <cstring>
#include <unistd.h>
using namespace std;
int main(){
int ssock , csock ;
struct sockaddr_in server ;
server.sin_family = AF_INET ;
server.sin_port = htons(8088);
server.sin_addr.s_addr = inet_addr("127.0.0.1");
ssock = socket (AF_INET,SOCK_STREAM,0);
if (ssock == -1 ) {
cout << " Error " ; return 0 ;
}
bind(ssock , (sockaddr *)&server ,sizeof(server));
listen(ssock,5);
socklen_t size = sizeof (server );
fstream fin("text.txt",ios::in);
string s((istreambuf_iterator<char>(fin)),istreambuf_iterator<char>());
fin.close();
//cout<<s;
int len = s.size();
if(len % 4 != 0 ) {
s.pop_back();
int i = len % 4 ;
i = 4 - i ;
while(i){s.push_back(' ');i--;}
s.push_back('\0');
}
cout<<s<<"\n"<<s.size()<<"\n";
while(csock = accept(ssock,(sockaddr *)&server ,&size)){
cout<<"\n Connection Accpeted \n" ;
/*int s = 172;
send(csock , (void *)&s, sizeof(s),0);*/
int i = 0;
i = 0 ;
while(i <= s.size()){
string temp =s.substr(i,4);
cout<<temp<<"\n";
cout<<send(csock,(void *)temp.c_str() ,4,0);
i+=4;
}
close(csock);
}
return 0 ;
}
发送或接收时是否有任何问题,有时候会陷入困境。
答案 0 :(得分:1)
void * buff ;
int len;
while(len = recv(ssock , buff ,4,0 )){
cout<<(char *)buff<<len<<"\n";
}
这里至少有三个错误:
您将buff
的值传递给recv
,但您尚未设置任何值。所以你要传递垃圾。
当您将char *
传递给cout
时,它必须是C风格的字符串。您无法使用它来打印从连接中收到的任意数据。首先,它如何知道要打印多少字节?
您不会处理recv
返回的否定值。
答案 1 :(得分:0)
检查recv的返回值是否为-ve值。否则,你会错过任何错误。
这些调用返回接收的字节数,如果发生错误则返回-1。当对等体执行有序关闭时,返回值将为0。