我正在处理的问题是,在成功发送数据后,我从客户端收到了第一个响应,但第二个响应是在他提交了他的详细信息并且没有提交之后。 你知道为什么会这样吗? 这是我的代码:
sock->listenAndAccept();
string url="HTTP/1.1 302 Found \r\nContent-Type: text/html; charset=utf8 \r\nContent- Length:279\r\n\r\n<!DOCTYPE html><html><head><title>Creating an HTML Element</title></head><body><form name=\"input\" action=\"login.html\" method=\"get\">user name: <input type=\"text\" name=\"user\"><br>password: <input type=\"text\" name=\"password\"><input type=\"submit\" value=\"Submit\"></form></body></html>";
sock->send(url.data(),url.length());
char buffer[1000];
sock->recv(buffer, 1000);
cout<<buffer<<endl;
sock->recv(buffer, 1000);
cout<<buffer<<endl;
听取并接受功能:
TCPSocket* TCPSocket::listenAndAccept(){
int rc = listen(socket_fd, 1);
if (rc<0){
return NULL;
}
size_t len = sizeof(peerAddr);
bzero((char *) &peerAddr, sizeof(peerAddr));
int connect_sock = accept(socket_fd, (struct sockaddr *)&peerAddr,(unsigned int *)&len);
return new TCPSocket(connect_sock,serverAddr,peerAddr);
}
recv功能:
int TCPSocket::recv(char* buffer, int length){
return read(socket_fd,buffer,length);
}
答案 0 :(得分:1)
TCP是面向流的协议。您可能已经在第一次recv中读取了所有消息。检查接收数据的大小,看它是否与预期输出匹配。
答案 1 :(得分:0)
永远总是(我不能经常这么说)检查recv
的返回值。 recv
会读取最多您要求的金额。如果您确定自己要求的金额已经开始,那么您必须围绕recv
缓冲传入的数据进行循环,直到您收到预期接收的数据为止。
当您使用非常快的localhost接口在本地计算机上进行测试时,这种类型的错误往往会隐藏在那里,然后在您开始在不同主机上运行客户端和服务器时立即浮出水面。
当你从测试代码转到实际代码时,你还必须处理零长度响应(客户端关闭套接字)和错误代码(&lt; 0响应)。
最后,请发布您的客户端代码。那里也可能存在漏洞。