如图,我在使用ctrl+c强制退出echoclient程序后,再次启动echoclient,没有连接问题,但无法实现回射。
源码如下
echoserver.c
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
//#define SUM(a,b) a+b
#define ERR_EXIT(m)\
do{\
perror(m);\
exit(EXIT_FAILURE);\
}while(0)
int main(){
int listenfd;
//listenfd=socket(PF_INET,SOCK_STREAM,0)
if((listenfd=socket(PF_INET,SOCK_STREAM,IPPROTO_TCP))<0)
ERR_EXIT("socket");
struct sockaddr_in servaddr;//ipv4 ip address
memset(&servaddr,0,sizeof(servaddr));//initial
servaddr.sin_family=AF_INET;// 地址族
servaddr.sin_port=htons(5188);//转换为网络字节序
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//转换为网络字节序
//servaddr.sin_addr.s_addr=inet_addr("127.0.0.1");
//inet_aton("127.0.0.1",&servaddr.sin_addr);
if(bind(listenfd,(struct sockaddr*)&servaddr,sizeof(servaddr))<0)
ERR_EXIT("bind");//绑定失败
//printf("%d\n",listen(listenfd,5)<0);
if((listen(listenfd,5))==-1)//将套接字转换为被动套接字 成功返回0,失败-1
{//printf("%d\n",errno);
//printf("%d\n",listen(listenfd,5)<0);
ERR_EXIT("listen");//监听失败,打印错误
}
struct sockaddr_in peeraddr;
socklen_t peerlen=sizeof(peeraddr);
int conn;
if((conn=accept(listenfd,(struct sockaddr*)&peeraddr,&peerlen))<0)//返回客户端主动套接字的描述符
ERR_EXIT("accept");
char recvbuf[1024];
while(1){
memset(recvbuf,0,sizeof(recvbuf));
int ret = read(conn,recvbuf,sizeof(recvbuf));
fputs(recvbuf,stdout);
write(conn,recvbuf,ret);
}
close(conn);
close(listenfd);
return 0;
}
echoclient.c
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
//#define SUM(a,b) a+b
#define ERR_EXIT(m)\
do{\
perror(m);\
exit(EXIT_FAILURE);\
}while(0)
int main(){
int sock;
//listenfd=socket(PF_INET,SOCK_STREAM,0)
if((sock=socket(PF_INET,SOCK_STREAM,IPPROTO_TCP))<0)
ERR_EXIT("socket");
struct sockaddr_in servaddr;//ipv4 ip address
memset(&servaddr,0,sizeof(servaddr));//initial
servaddr.sin_family=AF_INET;// 地址族
servaddr.sin_port=htons(5188);//转换为网络字节序
//servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//转换为网络字节序 使用自身地址
servaddr.sin_addr.s_addr=inet_addr("127.0.0.1");//指定服务器端地址,这里方便测试用的自身
if(connect(sock,(struct sockaddr*)&servaddr,sizeof(servaddr))<0)
ERR_EXIT("connect");
char sendbuf[1024]={0};
char recvbuf[1024]={0};
while(fgets(sendbuf,sizeof(sendbuf),stdin)!=NULL)
{
write(sock,sendbuf,strlen(sendbuf));
read(sock,recvbuf,sizeof(recvbuf));
fputs(recvbuf,stdout);
memset(sendbuf,0,sizeof(sendbuf));
memset(recvbuf,0,sizeof(sendbuf));
}
close(sock);
//客户端不需要绑定与接听
//inet_aton("127.0.0.1",&servaddr.sin_addr);
/*if(bind(listenfd,(struct sockaddr*)&servaddr,sizeof(servaddr))<0)
ERR_EXIT("bind");//绑定失败
if(listen(listenfd,SOMAXCONN)<0);//将套接字转换为被动套接字 成功返回0,失败-1
ERR_EXIT("listen");
struct sockaddr_in peeraddr;
socklen_t peerlen=sizeof(peeraddr);
int conn;
if((conn=accept(listenfd,(struct sockaddr*)&peeraddr,&peerlen))<0)//返回主动套接字的描述符
ERR_EXIT("accept");
char recvbuf[1024];
while(1){
memset(recvbuf,0,sizeof(recvbuf));
int ret = read(conn,recvbuf,sizeof(recvbuf));
fputs(recvbuf,stdout);
write(conn,recvbuf,ret);
}
*/
return 0;
}