多进程
#include<myhead.h>
#define PORT 8888 //端口号
#define IP "192.168.114.74" //IP地址
//定义函数处理客户端信息
int deal_cli_msg(int newfd, struct sockaddr_in cin)
{
//5、收发数据使用newfd完成通信
char buf[128] = "";
while(1)
{
//清空字符串
bzero(buf, sizeof(buf));
//read(newfd, buf, sizeof(buf)); //从套接字中读取客户端发来的消息
int res = recv(newfd, buf, sizeof(buf), 0); //从套接字中读取客户端发来的消息
//buf[strlen(buf)-1] = '\0';
//判断收到的结果
if(res == 0)
{
printf("客户端已经下线\n");
break;
}else if(res < 0)
{
perror("recv error");
return -1;
}
printf("[%s:%d]:%s\n", inet_ntoa(cin.sin_addr), ntohs(cin.sin_port), buf);
//将读取的信息,加上一些字符发送回去
strcat(buf, "*_*");
send(newfd, buf, sizeof(buf), 0);
}
close(newfd); //关闭通信的套接字
return 0;
}
//定义信号处理函数
void handler(int signo)
{
if(signo == SIGCHLD)
{
while(waitpid(-1, NULL, WNOHANG) > 0); //非阻塞形式回收僵尸进程
}
}
int main(int argc, const char *argv[])
{
//1、创建用于接受连接的套接字
int sfd = socket(AF_INET, SOCK_STREAM, 0);
if(sfd == -1)
{
perror("socket error");
return -1;
}
printf("socket success sfd = %d\n", sfd); //4
//设置端口号快速重用
int reuse = 1;
if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) == -1)
{
perror("setsockopt error");
return -1;
}
printf("设置端口快速重用成功 _%d_ %s_ %s_\n", __LINE__, __FILE__, __func__);
//2、绑定IP地址和端口号
//2.1、填充要绑定的地址信息结构体
struct sockaddr_in sin;
sin.sin_family = AF_INET; //表明是ipv4
sin.sin_port = htons(PORT); //端口号
sin.sin_addr.s_addr = inet_addr(IP); //IP地址
//2.2、绑定
if(bind(sfd, (struct sockaddr*)&sin, sizeof(sin))==-1)
{
perror("bind error");
return -1;
}
printf("bind success _%d_ %s_ %s_\n", __LINE__, __FILE__, __func__);
//3、将套接字设置成被动监听状态
if(listen(sfd, 128) == -1)
{
perror("listen error");
return -1;
}
printf("listen success _%d_ %s_ %s_\n", __LINE__, __FILE__, __func__);
//4、阻塞等待客户端连接请求,如果有新的客户端连接,则创建一个新的用于通信的套接字
//4.1、定义客户端地址信息结构体
struct sockaddr_in cin; //客户端地址信息结构体
cin.sin_family = AF_INET;
socklen_